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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mailclient2server.cpp

?? funambol windows mobile plugin source code, the source code is taken from the funambol site
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
        EXIT_ON_FAILED (hr);

        body = toMultibyte(buffer);
        delete [] buffer;

        if (!body) {
            LOG.error("null body for message %s", msg.getSubject());
            delete mcd; mcd = 0;
            goto FuncExit;
        }

        bodyPart.setContent(body);
        msg.setBody(bodyPart);
        delete [] body;

        // Set attachments ----------------------------------------------------
        if (msgprops[ePR_HASATTACH].ulPropTag == PR_HASATTACH) {
            attachCount = msgprops[ePR_HASATTACH].Value.ul;
            GetAttachments(pmsg, mcd);
        }

        // Message Id ---------------------------------------------------------
        char *msgId = NULL;
        if (msgprops[ePR_CUSTOM_MESSAGE_ID].ulPropTag == PR_CUSTOM_MESSAGE_ID) {
            msgId = toMultibyte(msgprops[ePR_CUSTOM_MESSAGE_ID].Value.lpszW);
            if (!msgId) {
                LOG.error("completeObject: error retrieving messageId from POOM");
            }
        }
        else {
            msgId = createMessageID(mcd->getEntryId());
            id = toWideChar(msgId);
            if (id) {
                // Set message id in POOM
                rgprops[cProps].ulPropTag = PR_CUSTOM_MESSAGE_ID;
                rgprops[cProps].Value.lpszW  = id;
                ++cProps;

                rgprops[cProps].ulPropTag = PR_LAST_MODIFICATION_TIME;
                rgprops[cProps].Value.ft  = ft;
                ++cProps;

            }
            else {
                LOG.error("completeObject: error converting message id: %s", id);
            }

        }
        // Set message id in outgoing message
        msg.setMessageId(msgId);
        delete [] msgId;

        // Other headers --------------------------------------------------------
        if (msgprops[ePR_CUSTOM_MESSAGE_HEADER].ulPropTag ==
            PR_CUSTOM_MESSAGE_HEADER) {
            hdrs = toMultibyte(msgprops[ePR_CUSTOM_MESSAGE_HEADER].Value.lpszW);
            if (hdrs) {
                msg.setHeaders(hdrs);
                //delete [] hdrs;
            }
            else {
                LOG.error("completeObject: error retrieving headers.");
            }
        }

        if (cProps > 0) {
            HRESULT hhr = pmsg->SetProps(cProps, rgprops, NULL);
            int k = 0;
        }
    }

FuncExit:
    if (id) { delete [] id; id = NULL; }
    if (hdrs) {delete [] hdrs; hdrs = NULL; }
    return mcd;
}

IMAPISession* MailClient2Server::logOn() {

    IMAPISession *    pSession    =  NULL;
    HRESULT hr;
    // First log on to the store.
    hr = MAPILogonEx (NULL, NULL, NULL, NULL, &pSession);

    if (hr == S_OK)
        return pSession;
    else
        return NULL;

}

void MailClient2Server::logOff(IMAPISession* pSession) {
    if (pSession)
        RELEASE_OBJ (pSession);
}

MailClientData* MailClient2Server::getFirstItem(BOOL keyOnly) {
    LOG.debug("Enter into getFirstItem function");
    allTot = 0;
    mailAll = -2;
    elementIndex = -2;

    for (int i = 0; i < folderNumber; i++) {
        allTot += entryListArray[i].cValues;
    }

    // send nr of mails from client, slow-sync, set -1 to wParam to signal that these are items from client
    if(HwndFunctions::wnd)
        SendMessage(HwndFunctions::wnd, ID_MYMSG_TOTAL_ITEMS, SOURCE_MAIL, (LPARAM)allTot);

    if (allTot == 0) {
        LOG.debug("Exiting from getFirstItem function. No more item");
        return NULL;
    }

    if (allTot > 0) {
        mailAll++;       // from -2 -> -1
        elementIndex++;  // from -2 -> -1
    }
    arrayIndex = 0;
    LOG.debug("Exiting from getFirstItem function");
    return getNextItem(keyOnly);

}

MailClientData* MailClient2Server::getNextItem(BOOL keyOnly) {

    LOG.debug("Enter into getNextItem function");

    IMAPISession *    pSession    = NULL;
    HRESULT           hr          = NULL;
    IMessage*         pmsg        = NULL;
    ULONG             returned    = 0;
    int               tot         = 0;

    if (allTot == 0) {
        LOG.debug("Exiting from getNextItem function. No more item");
        return NULL;
    }
    MailClientData* mailClientData = NULL;

    mailAll++;
    elementIndex++;
    if (arrayIndex == folderNumber)
        return NULL;
      // if the current folder has no updated items, increments arrayIndex immediately

    if (entryListArray[arrayIndex].cValues == 0) {
        for (int k = 0; (k < folderNumber && arrayIndex < folderNumber); k++) {
            if (entryListArray[arrayIndex].cValues == 0)
                arrayIndex++;
             else
                break;
        }
    }
    pSession = logOn();

    if (pSession == NULL)
        goto FuncExit;

    if (mailAll < allTot) {

        hr = pSession->OpenEntry(entryListArray[arrayIndex].lpbin[elementIndex].cb,
            (ENTRYID*)entryListArray[arrayIndex].lpbin[elementIndex].lpb,
            NULL,
            MAPI_BEST_ACCESS,
            &returned,
            (IUnknown **) &pmsg);
        EXIT_ON_FAILED (hr);
        ASSERT (pmsg);

        mailClientData = completeObject(pmsg, folderToSync[arrayIndex], FALSE, keyOnly);

        if ((unsigned long)elementIndex == entryListArray[arrayIndex].cValues -1) {
            arrayIndex++;
            elementIndex = -1;
        }

    }

    logOff(pSession);

FuncExit:
    LOG.debug("Exiting from getNextItem function");
    return mailClientData;
}

MailClientData* MailClient2Server::getFirstNewItem() {

    LOG.debug("Enter into getFirstNewItem function");
    allTot = 0;
    mailNew = -2;       // from -2 -> -1
    elementIndex = -2;  // from -2 -> -1

    for (int i = 0; i < folderNumber; i++) {
        allTot += newMessagesArray[i].cValues;
    }

    if (allTot == 0) {
        LOG.debug("Exiting from getFirstNewItem function. No more item");
        return NULL;
    }

    if (allTot > 0) {
        mailNew++;       // from -2 -> -1
        elementIndex++;  // from -2 -> -1
    }
    arrayIndex = 0;

    LOG.debug("Exiting from getFirstNewItem function");
    return getNextNewItem();

}

MailClientData* MailClient2Server::getNextNewItem() {

    LOG.debug("Enter into getNextNewItem function");
    IMAPISession *    pSession    = NULL;
    HRESULT           hr          = NULL;
    IMessage*         pmsg        = NULL;
    ULONG             returned    = 0;
    MailClientData*   mailClientData = NULL;

    if (allTot == 0) {
        LOG.debug("Exiting from getNextNewItem function. No more item");
        return NULL;
    }

    mailNew++;
    elementIndex++;

     if (arrayIndex == folderNumber)
        return NULL;
     // if the current folder has no updated items, increments arrayIndex immediately
    if (newMessagesArray[arrayIndex].cValues == 0) {
        for (int k = 0; (k < folderNumber && arrayIndex < folderNumber); k++) {
            if (newMessagesArray[arrayIndex].cValues == 0)
                arrayIndex++;
            else
                break;
        }
    }

    pSession = logOn();

    if (pSession == NULL)
        goto FuncExit;

    if (mailNew < allTot) {

        hr = pSession->OpenEntry(newMessagesArray[arrayIndex].lpbin[elementIndex].cb,
            (ENTRYID*)newMessagesArray[arrayIndex].lpbin[elementIndex].lpb,
            NULL,
            MAPI_BEST_ACCESS,
            &returned,
            (IUnknown **) &pmsg);
        EXIT_ON_FAILED (hr);
        ASSERT (pmsg);

        mailClientData = completeObject(pmsg, folderToSync[arrayIndex], FALSE);

        if ((unsigned long)elementIndex == newMessagesArray[arrayIndex].cValues -1) {
            arrayIndex++;
            elementIndex = -1;
        }
    }

    logOff(pSession);

FuncExit:
    LOG.debug("Exiting from getNextNewItem function");
    return mailClientData;
}


MailClientData* MailClient2Server::getFirstUpdatedItem() {

    LOG.debug("Enter into getFirstUpdatedItem function");
    allTot = 0;
    mailUpdated = -2;       // from -2 -> -1
    elementIndex = -2;  // from -2 -> -1

    for (int i = 0; i < folderNumber; i++) {
        allTot += updatedMessagesArray[i].cValues;
    }

    if (allTot == 0) {
        LOG.debug("Exiting from getFirstUpdatedItem function. No more item");
        return NULL;
    }

    if (allTot > 0) {
        mailUpdated++;       // from -2 -> -1
        elementIndex++;  // from -2 -> -1
    }
    arrayIndex = 0;

    LOG.debug("Exiting from getFirstUpdatedItem function");
    return getNextUpdatedItem();

}

MailClientData* MailClient2Server::getNextUpdatedItem() {

    LOG.debug("Enter into getNextUpdatedItem function");
    IMAPISession *    pSession    = NULL;
    HRESULT           hr          = NULL;
    IMessage*         pmsg        = NULL;
    ULONG             returned    = 0;
    MailClientData*   mailClientData = NULL;

    if (allTot == 0) {
        LOG.debug("Exiting from getNextUpdatedItem function. No more item");
        return NULL;
    }

    mailUpdated++;
    elementIndex++;

     if (arrayIndex == folderNumber)
        return NULL;
    // if the current folder has no updated items, increments arrayIndex immediately
    if (updatedMessagesArray[arrayIndex].cValues == 0) {
        for (int k = 0; (k < folderNumber && arrayIndex < folderNumber); k++) {
            if (updatedMessagesArray[arrayIndex].cValues == 0)
                arrayIndex++;
            else
                break;
        }
    }
    pSession = logOn();

    if (pSession == NULL)
        goto FuncExit;

    if (mailUpdated < allTot) {

        hr = pSession->OpenEntry(updatedMessagesArray[arrayIndex].lpbin[elementIndex].cb,
            (ENTRYID*)updatedMessagesArray[arrayIndex].lpbin[elementIndex].lpb,
            NULL,
            MAPI_BEST_ACCESS,
            &returned,
            (IUnknown **) &pmsg);
        EXIT_ON_FAILED (hr);
        ASSERT (pmsg);

        //
        // The updated parameter
        //
        mailClientData = completeObject(pmsg, folderToSync[arrayIndex], TRUE);

        if ((unsigned long)elementIndex == updatedMessagesArray[arrayIndex].cValues -1) {
            arrayIndex++;
            elementIndex = -1;
        }
    }

    logOff(pSession);

FuncExit:
    LOG.debug("Exiting from getNextUpdatedItem function");
    return mailClientData;
}

MailClientData* MailClient2Server::getFirstDeletedItem() {

    LOG.debug("Enter into getFirstDeletedItem function");
    allTot = 0;
    mailDeleted  = -2;  // from -2 -> -1
    elementIndex = -2;  // from -2 -> -1

    for (int i = 0; i < folderNumber; i++) {
        allTot += deletedMessagesArray[i]->size();
    }

    if (allTot == 0) {
        LOG.debug("Exiting from getFirstDeletedItem function. No more item");
        return NULL;
    }

    if (allTot > 0) {
        mailDeleted++;       // from -2 -> -1
        elementIndex++;  // from -2 -> -1
    }
    arrayIndex = 0;

    LOG.debug("Exiting from getFirstDeletedItem function");
    return getNextDeletedItem();

}

MailClientData* MailClient2Server::getNextDeletedItem() {

    LOG.debug("Enter into getNextDeletedItem function");

    if (allTot == 0) {
        LOG.debug("Exiting from getNextDeletedItem function. No more item");
        return NULL;
    }

    MailClientData* mailClientData = NULL;
    wchar_t* r = NULL;
    mailDeleted++;
    elementIndex++;

    // if arrayIndex is the same as folder number we are at the end of the array
    if (arrayIndex == folderNumber)
        return NULL;

    // if the current folder has no deleted items, increments arrayIndex immediately
    if (deletedMessagesArray[arrayIndex]->size() == 0) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲综合在线| 美国毛片一区二区三区| 国产老肥熟一区二区三区| 欧美日韩一区 二区 三区 久久精品| 国产日产精品1区| 全部av―极品视觉盛宴亚洲| 欧美在线免费观看视频| 亚洲精品欧美综合四区| 91小视频在线免费看| 中文字幕制服丝袜一区二区三区| 国产成人在线免费观看| 久久只精品国产| 国产又粗又猛又爽又黄91精品| 这里只有精品99re| 麻豆国产精品777777在线| 日韩欧美aaaaaa| 国产麻豆91精品| 久久女同精品一区二区| 国产精品系列在线播放| 国产欧美综合在线| 99久久精品国产精品久久| 亚洲欧美日韩一区| 欧美日韩精品专区| 久久国产免费看| 中文字幕av一区二区三区| av电影在线观看一区| 亚洲最新在线观看| 欧美日本免费一区二区三区| 久久疯狂做爰流白浆xx| 国产精品久久久久桃色tv| 欧美日韩一区三区四区| 久久99精品国产麻豆婷婷洗澡| 国产日韩欧美不卡在线| 日本精品一级二级| 蜜桃免费网站一区二区三区| 日本一区二区三区国色天香 | 欧美在线播放高清精品| 麻豆视频一区二区| 亚洲免费在线视频一区 二区| 日韩一区二区三区视频在线| 91片在线免费观看| 日本大胆欧美人术艺术动态| 国产亚洲成年网址在线观看| 在线观看成人免费视频| 国产高清久久久| 日本不卡高清视频| 亚洲综合在线第一页| 日本一区二区视频在线观看| 欧美午夜精品免费| 91同城在线观看| 久久99国产精品免费| 免费高清不卡av| 亚洲一线二线三线久久久| 精品久久五月天| 欧美久久久久久蜜桃| 91看片淫黄大片一级| 高清视频一区二区| 国产一区二区在线观看免费| 三级欧美韩日大片在线看| 一区二区三区在线影院| 国产精品二区一区二区aⅴ污介绍| 欧美一级片免费看| 884aa四虎影成人精品一区| 在线免费不卡电影| 一本到不卡精品视频在线观看 | 国产精品66部| 国产一区二区导航在线播放| 乱一区二区av| 麻豆极品一区二区三区| 美洲天堂一区二卡三卡四卡视频| 亚欧色一区w666天堂| 五月婷婷色综合| 日韩av中文字幕一区二区三区| 五月婷婷欧美视频| 日本亚洲最大的色成网站www| 日韩制服丝袜先锋影音| 麻豆国产精品官网| 国产精品一区二区三区乱码| 国产大陆亚洲精品国产| 成人免费视频app| 91小视频免费看| 欧美久久一二三四区| 3d成人h动漫网站入口| 精品嫩草影院久久| 国产精品日日摸夜夜摸av| 国产精品国产三级国产三级人妇 | 99久久99久久免费精品蜜臀| 色综合天天综合在线视频| 91国产成人在线| 欧美一区二区私人影院日本| 久久婷婷综合激情| 亚洲色图制服丝袜| 日韩激情在线观看| av一二三不卡影片| 欧美视频一区二区| 久久一夜天堂av一区二区三区 | 国产一区999| 欧美三区在线视频| 久久―日本道色综合久久| 亚洲国产成人精品视频| 国产一区二区在线影院| 欧美体内she精视频| 欧美激情在线观看视频免费| 亚洲午夜一区二区| 国产高清精品网站| 欧美日本在线一区| 1000精品久久久久久久久| 蜜桃久久久久久| 欧美图区在线视频| 亚洲女女做受ⅹxx高潮| 国产精品18久久久久久久久| 7777精品久久久大香线蕉| 亚洲欧美日韩一区二区 | 国产午夜精品一区二区| 青青草成人在线观看| 欧美在线观看一区| 99久久伊人精品| 久久精品免费在线观看| 激情综合五月婷婷| 精品久久久影院| 免费在线观看成人| 日韩一区二区不卡| 久久99精品久久久久婷婷| 5858s免费视频成人| 亚洲成精国产精品女| 欧美日韩一区二区三区四区| 亚洲第一激情av| 欧美疯狂做受xxxx富婆| 天天爽夜夜爽夜夜爽精品视频| 欧美日韩小视频| 丝袜亚洲精品中文字幕一区| 欧美日韩激情在线| 午夜精品久久久久久久久| 6080亚洲精品一区二区| 理论电影国产精品| 久久久精品中文字幕麻豆发布| 国产精品一二二区| 国产精品久久久久久久午夜片| 91小宝寻花一区二区三区| 亚洲午夜久久久| 欧美一区二区三区视频免费播放| 免费观看久久久4p| 欧美韩国日本综合| 欧美色涩在线第一页| 理论片日本一区| 欧美专区亚洲专区| 中文字幕精品一区二区精品绿巨人 | 久久久久国产精品厨房| 欧美日韩1区2区| 成人深夜福利app| 亚洲狠狠爱一区二区三区| 欧美成人官网二区| 99麻豆久久久国产精品免费优播| 亚洲一区免费视频| 2021久久国产精品不只是精品| aaa亚洲精品| 麻豆精品久久精品色综合| 中文字幕第一区| 欧美一卡2卡三卡4卡5免费| www.亚洲精品| 极品少妇一区二区| 亚洲电影视频在线| 中文字幕视频一区二区三区久| 制服丝袜亚洲精品中文字幕| 99麻豆久久久国产精品免费| 日韩国产欧美三级| 一区二区三区国产精品| 国产精品无遮挡| 欧美成人性战久久| 91精品国产91综合久久蜜臀| 色综合天天性综合| 不卡电影一区二区三区| 免费看日韩a级影片| 亚洲国产精品一区二区www在线| 亚洲丝袜另类动漫二区| 国产精品国产三级国产aⅴ无密码| 亚洲国产精品国自产拍av| 久久久久久久久免费| 久久亚洲捆绑美女| 久久久99精品免费观看| 国产色一区二区| 中文字幕佐山爱一区二区免费| 中文字幕制服丝袜一区二区三区| 国产精品国产自产拍在线| 亚洲欧美视频一区| 亚洲一区免费观看| 日av在线不卡| 黄页网站大全一区二区| 成人免费精品视频| 日本乱人伦aⅴ精品| 欧美女孩性生活视频| 欧美videos大乳护士334| 国产精品美女久久久久久久| 亚洲欧美日韩在线| 久久99精品一区二区三区| 成人av资源下载| 91精品国产91热久久久做人人| 国产精品午夜在线| 亚洲va欧美va人人爽| 国产精品一区二区不卡|