亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? parser.cpp

?? funambol windows mobile plugin source code, the source code is taken from the funambol site
?? CPP
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
/*
 * Copyright (C) 2003-2007 Funambol, Inc.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY, TITLE, NONINFRINGEMENT or FITNESS FOR A PARTICULAR
 * PURPOSE.  See the GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
 * 02111-1307  USA
 */


#include "syncml/parser/Parser.h"

SyncML* Parser::getSyncML(const char*xml) {
    SyncBody* syncBody = NULL;
    SyncHdr*  syncHdr  = NULL;
    SyncML*   syncML   = NULL;
    unsigned int pos = 0;
    char* t = NULL;
    t = XMLProcessor::copyElementContent(xml, SYNC_HDR, &pos);
    syncHdr  = getSyncHdr (t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent(xml, SYNC_BODY, &pos);
    syncBody = getSyncBody(t);
    if (t) { delete [] t; t = NULL; }
    syncML = new SyncML(syncHdr, syncBody);

    deleteSyncHdr (&syncHdr);
    deleteSyncBody(&syncBody);

    return syncML;

}

SyncHdr* Parser::getSyncHdr(const char*xml) {

    SessionID*   sessionID = NULL;
    VerDTD*      verDTD    = NULL;
    VerProto*    verProto  = NULL;
    Source*      source    = NULL;
    Target*      target    = NULL;
    Cred*        cred      = NULL;
    char*     respURI   = NULL;
    char*     msgID     = NULL;
    BOOL         noResp    = NULL;
    char*     tmp       = NULL;
    Meta*        meta      = NULL;

    SyncHdr*     ret       = NULL;
    unsigned int pos = 0;
    char* t = NULL;

    t = XMLProcessor::copyElementContent(xml, SESSION_ID, NULL);
    sessionID = getSessionID(t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent (xml, VER_DTD, NULL);
    verDTD = getVerDTD(t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent (xml, VER_PROTO, NULL);
    verProto = getVerProto(t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent (xml, SOURCE, NULL);
    source = getSource(t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent (xml, TARGET, NULL);
    target = getTarget(t);
    if (t) { delete [] t; t = NULL; }
    t = XMLProcessor::copyElementContent (xml, CRED, NULL);
    cred = getCred(t);
    if (t) { delete [] t; t = NULL; }
    msgID = XMLProcessor::copyElementContent(xml, MSG_ID, NULL);
    respURI = XMLProcessor::copyElementContent(xml, RESP_URI, NULL);
    t = XMLProcessor::copyElementContentLevel(xml, META, NULL);
    meta = getMeta(t);
    if (t) { delete [] t; t = NULL; }
    tmp = XMLProcessor::copyElementContent(xml, NO_RESP, NULL);

    if (tmp) {
        wcscmpIgnoreCase(tmp, "TRUE") ? noResp = TRUE : noResp = FALSE;
    }
    ret = new SyncHdr(verDTD, verProto, sessionID, msgID, target, source, respURI, noResp, cred, meta);

    deleteVerDTD(&verDTD);
    deleteVerProto(&verProto);
    deleteSessionID(&sessionID);
    deleteSource(&source   );
    deleteTarget(&target);
    deleteCred(&cred);
    deleteMeta(&meta);
    safeDel(&respURI);
    safeDel(&msgID);
    safeDel(&tmp);

    return ret;
}

Cred* Parser::getCred(const char*xml) {
    Cred* ret              = NULL;
    Authentication* auth   = NULL;

    auth = getAuthentication(xml);
    if (auth) {
        ret = new Cred(auth);
    }

    deleteAuthentication(&auth);

    return ret;
}

Authentication* Parser::getAuthentication(const char*xml) {
    Authentication* ret        = NULL;

    char* data       = NULL;
    Meta*  meta       = NULL;

    unsigned int pos = 0;
    char* t = NULL;

    data = XMLProcessor::copyElementContent (xml, DATA , NULL);
    t = XMLProcessor::copyElementContentLevel (xml, META , NULL);
    meta = getMeta(t);
    if (t) {delete [] t; t = NULL;}
    if (data || meta) {
        ret = new Authentication(meta, data);
    }
    safeDel(&data);
    deleteMeta(&meta);

    return ret;
}

Meta* Parser::getMeta(const char*xml) {
    Meta* ret        = NULL;
    MetInf* metInf   = NULL;

    metInf = getMetInf(xml);
    if (metInf) {
        ret = new Meta();
        ret->setMetInf(metInf);
    }

    deleteMetInf(&metInf);

    return ret;
}

MetInf* Parser::getMetInf(const char*xml) {
    MetInf* ret             = NULL;

    char*     format     = NULL;
    char*     type       = NULL;
    char*     mark       = NULL;
    Anchor*      anchor     = NULL;
    char*     version    = NULL;
    NextNonce*   nextNonce  = NULL;
    long         maxMsgSize = 0;
    long         maxObjSize = 0;
    long         size       = 0;
    ArrayList*   emi        = NULL;
    Mem*         mem        = NULL;

    char*         maxMsgSizeW   = NULL;
    char*         maxObjSizeW   = NULL;
    char*         sizeW         = NULL;

    // get all the values

    format       = XMLProcessor::copyElementContent (xml, FORMAT   , NULL);
    type         = XMLProcessor::copyElementContent (xml, TYPE     , NULL);
    mark         = XMLProcessor::copyElementContent (xml, MARK     , NULL);

    anchor       = getAnchor(xml);
    version      = XMLProcessor::copyElementContent (xml, VERSIONSTR       , NULL);
    nextNonce    = getNextNonce(xml);

    maxMsgSizeW  = XMLProcessor::copyElementContent (xml, MAX_MESSAGE_SIZE     , NULL);
    maxObjSizeW  = XMLProcessor::copyElementContent (xml, MAX_OBJ_SIZE     , NULL);
    sizeW        = XMLProcessor::copyElementContent (xml, SIZE             , NULL);

    if (maxMsgSizeW) {
        maxMsgSize = strtol(maxMsgSizeW, NULL, 10);
    }
    if (maxObjSizeW) {
        maxObjSize = strtol(maxObjSizeW, NULL, 10);
    }
    if (sizeW) {
        size = strtol(sizeW, NULL, 10);
    }

    emi          = getEMI(xml);
    mem          = getMem(xml);

    // check if someting is null, 0 or zero lenght
    BOOL isToCreate = FALSE;
    isToCreate = NotNullCheck(7, format, type, mark, version, maxMsgSizeW, maxObjSizeW, sizeW)
                 || NotZeroArrayLenght(1, emi)
                 || (mem)
                 || (anchor)
                 || (nextNonce);

    if (isToCreate) {
        ret = new MetInf(format, type, mark, size, anchor, version, nextNonce, maxMsgSize,
                         maxObjSize, emi, mem);
    }
    deleteAll(7, &format, &type, &mark, &version, &maxMsgSizeW, &maxObjSizeW, &sizeW);

    deleteAnchor(&anchor);
    deleteNextNonce(&nextNonce);
    deleteArrayList(&emi);
    deleteMem(&mem);

    return ret;
}


ArrayList* Parser::getSources(const char*xml) {

    Source* source = NULL;
    SourceArray* sourceArray = NULL;
    unsigned int pos = 0, previous = 0;
    ArrayList* list = new ArrayList();

    char* t = NULL;
    t = XMLProcessor::copyElementContent(&xml[pos], SOURCE, &pos);
    while ((source = getSource(t)) != NULL) {
        if (source) {
            sourceArray = new SourceArray(source);
            list->add(*sourceArray); // in the ArrayList NULL element cannot be inserted
            deleteSource(&source);
            deleteSourceArray(&sourceArray);
        }
        pos += previous;
        previous = pos;
        if (t) { delete [] t; t = NULL; }
        t = XMLProcessor::copyElementContent(&xml[pos], SOURCE, &pos);
    }
    if (t) { delete [] t; t = NULL;}
    return list;
}


Source* Parser::getSource(const char*xml) {
    Source* ret      = NULL;
    char* locURI  = NULL;
    char* locName = NULL;
    locURI  = XMLProcessor::copyElementContent (xml, LOC_URI, NULL);
    locName = XMLProcessor::copyElementContent (xml, LOC_NAME, NULL);

    if (NotNullCheck(2, locURI, locName)) {
        ret = new Source(locURI, locName);
    }

    safeDel(&locURI);
    safeDel(&locName);

    return ret;
}

Target* Parser::getTarget(const char*xml) {
    Target*  ret      = NULL;
    char* locURI   = NULL;
    char* locName  = NULL;

    locURI  = XMLProcessor::copyElementContent (xml, LOC_URI, NULL);
    locName = XMLProcessor::copyElementContent (xml, LOC_NAME, NULL);

    if (NotNullCheck(2, locURI, locName)) {
        ret = new Target(locURI, locName);
    }

    safeDel(&locURI);
    safeDel(&locName);

    return ret;
}

Anchor* Parser::getAnchor(const char*xml) {
    Anchor*  ret    = NULL;
    char* last   = NULL;
    char* next   = NULL;

    last  = XMLProcessor::copyElementContent (xml, LAST, NULL);
    next  = XMLProcessor::copyElementContent (xml, NEXT, NULL);

    if (NotNullCheck(2, last, next)) {
        ret = new Anchor(last, next);
    }

    safeDel(&next);
    safeDel(&last);

    return ret;
}

NextNonce* Parser::getNextNonce(const char*xml) {
    NextNonce* ret   = NULL;
    char* value   = NULL;

    value  = XMLProcessor::copyElementContent (xml, NEXT_NONCE, NULL);

    if (NotNullCheck(1, value)) {

        ret = new NextNonce(value);
    }

    safeDel(&value);
    return ret;
}

Mem* Parser::getMem(const char*xml) {
    Mem* ret            = NULL;
    char* freeMemW   = NULL;
    char* sharedMemW = NULL;
    char* freeIDW    = NULL;

    BOOL    sharedMem   = NULL;
    long    freeMem     = 0;
    long    freeID      = 0;

    BOOL isToCreate = FALSE;

    freeMemW    = XMLProcessor::copyElementContent (xml, FREE_MEM,   NULL);
    sharedMemW  = XMLProcessor::copyElementContent (xml, SHARED_MEM, NULL);
    freeIDW     = XMLProcessor::copyElementContent (xml, FREE_ID,    NULL);

    isToCreate = NotNullCheck(3, freeMemW, sharedMemW, freeIDW);

    if (freeMemW != NULL) {
        freeMem = strtol(freeMemW, NULL, 10);
    }
    if (freeIDW != NULL) {
        freeID = strtol(freeIDW, NULL, 10);
    }
    if (sharedMemW != NULL) {
        sharedMem = strtol(sharedMemW, NULL, 10);
    }

    if (isToCreate) {
        ret = new Mem(sharedMem, freeMem, freeID);
    }

    safeDel(&freeMemW);
    safeDel(&freeIDW);
    safeDel(&sharedMemW);

    return ret;
}


SessionID* Parser::getSessionID(const char*content) {
    SessionID* ret = NULL;
    if (content) {
        ret = new SessionID(content);
    }
    return ret;
}

VerDTD* Parser::getVerDTD(const char*content) {
    VerDTD* ret = NULL;
    if (content) {
        ret = new VerDTD(content);
    }
    return ret;
}

VerProto* Parser::getVerProto(const char*content) {
    VerProto* ret = NULL;
    if (content) {
        ret = new VerProto(content);
    }
    return ret;
}

SyncBody* Parser::getSyncBody(const char*xml) {

    SyncBody* syncBody   = NULL;
    BOOL finalMsg        = FALSE;
    ArrayList* commands;
    unsigned int pos = 0;
    char* t = NULL;
    commands = getCommands(xml);
    t = XMLProcessor::copyElementContent(xml, FINAL_MSG, NULL);
    finalMsg = getFinalMsg(t);
    if (t) {delete [] t; t = NULL;}
    syncBody = new SyncBody(commands, finalMsg);

    deleteArrayList(&commands);

    return syncBody;
}

/*
* The sequence tag can contains the common commands (Add, Replace, Delete, Copy) and
* Alert
* Exec
* Get
* Map
*
* Atomic
* Sync
*/
Sequence* Parser::getSequence(const char*xml) {

    Sequence* ret           = NULL;

    Meta*   meta            = NULL;
    BOOL    noResp          = NULL;
    CmdID*  cmdID           = NULL;
    ArrayList* commands     = new ArrayList();
    Sync* sync              = NULL;
    Atomic* atomic          = NULL;

    Alert* alert            = NULL;
    Map*   map              = NULL;
    Get*   get              = NULL;
    Exec* exec              = NULL;

    ArrayList* list     = new ArrayList();
    unsigned int pos = 0, previous = 0;

    char* t = NULL;
    t = XMLProcessor::copyElementContent(xml, CMD_ID, NULL);
    cmdID = getCmdID(t);
    if (t) {delete [] t; t = NULL;}
    t = XMLProcessor::copyElementContentLevel (xml,  META  , NULL);
    meta = getMeta(t);
    if (t) {delete [] t; t = NULL;}
    t = XMLProcessor::copyElementContent (xml, NO_RESP, NULL);
    noResp   = getNoResp(t);
    if (t) {delete [] t; t = NULL;}
    // list of commands that must not be leaf of Sync and Atomic
    commands = getCommonCommandList(xml, "Atomic&Sync");

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色中色一区二区| 中文字幕av一区 二区| 欧美图区在线视频| 欧美专区亚洲专区| 91福利在线观看| 在线看日本不卡| 欧美综合天天夜夜久久| 欧美日韩性生活| 欧美日韩在线免费视频| 精品视频在线免费看| 欧美丝袜丝交足nylons图片| 欧洲av在线精品| 欧美日韩中文字幕精品| 538prom精品视频线放| 91精选在线观看| 精品99一区二区| 日本成人在线不卡视频| 视频一区在线视频| 热久久国产精品| 精品一区二区三区香蕉蜜桃| 看片的网站亚洲| 国产乱码精品一区二区三| 国产成人av影院| 97se亚洲国产综合自在线观| 色狠狠av一区二区三区| 欧美日韩亚洲高清一区二区| 日韩一区二区在线观看视频| 欧美精品一区二区高清在线观看 | 日韩一区二区三| 久久天堂av综合合色蜜桃网| 国产日韩欧美一区二区三区综合| 亚洲欧洲三级电影| 亚洲二区在线视频| 国产一区 二区| 91网页版在线| 3atv在线一区二区三区| 久久久99久久精品欧美| 国产精品久久久久影院亚瑟 | 狠狠色综合色综合网络| 国产激情一区二区三区| 91网站最新地址| 欧美一区日本一区韩国一区| 久久精品在这里| 亚洲综合自拍偷拍| 精品亚洲aⅴ乱码一区二区三区| 成人涩涩免费视频| 欧美日韩成人综合在线一区二区| 久久综合久久综合久久| 亚洲丝袜自拍清纯另类| 欧美成人福利视频| 国产精一品亚洲二区在线视频| 欧美日韩国产高清一区二区三区 | 国产精品 日产精品 欧美精品| 丁香啪啪综合成人亚洲小说 | 久久综合中文字幕| 亚洲天堂福利av| 麻豆精品在线观看| 99在线热播精品免费| 91精品国产aⅴ一区二区| 国产区在线观看成人精品 | 99精品视频在线观看| 欧美一区二区三区在线看| 国产精品护士白丝一区av| 日本系列欧美系列| 91麻豆成人久久精品二区三区| 日韩欧美国产一区二区在线播放 | av一二三不卡影片| 日韩一区和二区| 一区二区三区精品在线观看| 国产精品一区二区无线| 欧美日本视频在线| 综合欧美亚洲日本| 国产精品亚洲专一区二区三区| 欧美日韩国产区一| 亚洲精品亚洲人成人网在线播放| 黄色日韩网站视频| 欧美一级免费观看| 亚洲制服丝袜av| 国产嫩草影院久久久久| 青草av.久久免费一区| 色狠狠色狠狠综合| 国产精品家庭影院| 国产成人午夜视频| 久久久亚洲午夜电影| 日本不卡123| 欧美老肥妇做.爰bbww视频| 亚洲欧美另类图片小说| 国产宾馆实践打屁股91| 精品国产网站在线观看| 日韩成人伦理电影在线观看| 日本电影欧美片| 中文字幕在线一区免费| 国产98色在线|日韩| 久久久夜色精品亚洲| 韩国一区二区三区| 欧美r级在线观看| 琪琪一区二区三区| 日韩视频一区在线观看| 天涯成人国产亚洲精品一区av| 欧美最猛黑人xxxxx猛交| 亚洲激情av在线| 色欧美乱欧美15图片| 亚洲日本va午夜在线影院| www.综合网.com| 国产精品久久精品日日| 成人免费av资源| 国产精品嫩草影院av蜜臀| 国产精品一线二线三线精华| 免费视频最近日韩| 日韩一级视频免费观看在线| 蜜桃一区二区三区在线| 精品久久99ma| 国产精品羞羞答答xxdd| 久久精品一二三| 成人国产精品免费观看| 中文字幕一区二区在线观看| 91丝袜高跟美女视频| 亚洲色大成网站www久久九九| 色婷婷久久99综合精品jk白丝| 亚洲欧美另类小说| 欧美日韩亚洲综合| 奇米一区二区三区| 国产亚洲人成网站| 北岛玲一区二区三区四区| 亚洲女人的天堂| 欧美日韩在线一区二区| 卡一卡二国产精品| 国产性色一区二区| 91丨九色丨黑人外教| 亚洲一区二区三区影院| 正在播放一区二区| 极品少妇xxxx精品少妇| 国产精品久久久久久久第一福利 | 成人国产精品免费观看动漫| 亚洲精品视频免费看| 亚洲成av人片在www色猫咪| 欧美人xxxx| 国产美女精品在线| 亚洲精品国产成人久久av盗摄 | 中文字幕乱码亚洲精品一区| 91麻豆免费在线观看| 日韩精品高清不卡| 国产三级欧美三级日产三级99 | 日韩无一区二区| 成人中文字幕合集| 亚洲国产日韩一级| 久久新电视剧免费观看| 91浏览器打开| 免费成人性网站| 成人欧美一区二区三区| 91超碰这里只有精品国产| 国产风韵犹存在线视精品| 亚洲乱码日产精品bd| 日韩精品一区二区三区视频| 成人av免费在线播放| 亚洲v中文字幕| 久久久国产精品麻豆| 欧美在线一二三| 国产在线精品免费| 亚洲国产综合在线| 国产亚洲成aⅴ人片在线观看| 欧美亚洲一区二区在线| 国产一区在线观看视频| 亚洲自拍偷拍麻豆| 久久97超碰色| 亚洲免费观看在线视频| 欧美成人综合网站| 91久久人澡人人添人人爽欧美 | 欧美一区二区三区视频免费播放| 国产成人午夜精品影院观看视频| 性久久久久久久久| 中文字幕一区二区三区不卡 | 日韩一级精品视频在线观看| thepron国产精品| 久久电影网站中文字幕| 亚洲午夜在线观看视频在线| 国产精品美日韩| 精品国产乱码久久久久久牛牛| 欧美午夜片在线观看| 成人久久视频在线观看| 久久不见久久见中文字幕免费| 亚洲综合一区二区精品导航| 国产精品二三区| 欧美精品一区二区蜜臀亚洲| 欧美一区欧美二区| 欧美丰满少妇xxxxx高潮对白| 99精品一区二区三区| 国产成人日日夜夜| 精品中文字幕一区二区| 天天色天天爱天天射综合| 亚洲人吸女人奶水| 日本一区二区三区四区在线视频 | 久久99久久精品| 天天av天天翘天天综合网| 亚洲精品美腿丝袜| 一色桃子久久精品亚洲| 欧美国产日韩在线观看| 国产日韩精品一区二区浪潮av| 欧美精品一区二区三区四区| 日韩免费电影一区|