diff options
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/abstract/MCMessageConstants.h | 3 | ||||
-rw-r--r-- | src/core/imap/MCIMAPMessage.cc | 16 | ||||
-rw-r--r-- | src/core/imap/MCIMAPMessage.h | 5 | ||||
-rw-r--r-- | src/core/imap/MCIMAPSearchExpression.cc | 21 | ||||
-rw-r--r-- | src/core/imap/MCIMAPSearchExpression.h | 6 | ||||
-rwxr-xr-x | src/core/imap/MCIMAPSession.cc | 17 |
6 files changed, 67 insertions, 1 deletions
diff --git a/src/core/abstract/MCMessageConstants.h b/src/core/abstract/MCMessageConstants.h index aa252243..92e04c6e 100644 --- a/src/core/abstract/MCMessageConstants.h +++ b/src/core/abstract/MCMessageConstants.h @@ -69,6 +69,7 @@ namespace mailcore { IMAPMessagesRequestKindGmailMessageID = 1 << 7, IMAPMessagesRequestKindGmailThreadID = 1 << 8, IMAPMessagesRequestKindExtraHeaders = 1 << 9, + IMAPMessagesRequestKindSize = 1 << 10, }; enum IMAPFetchRequestType { @@ -184,6 +185,8 @@ namespace mailcore { IMAPSearchKindBeforeReceivedDate, IMAPSearchKindOnReceivedDate, IMAPSearchKindSinceReceivedDate, + IMAPSearchKindSizeLarger, + IMAPSearchKindSizeSmaller, IMAPSearchKindGmailThreadID, IMAPSearchKindOr, IMAPSearchKindAnd, diff --git a/src/core/imap/MCIMAPMessage.cc b/src/core/imap/MCIMAPMessage.cc index 74b3459b..8d3c5c02 100644 --- a/src/core/imap/MCIMAPMessage.cc +++ b/src/core/imap/MCIMAPMessage.cc @@ -75,6 +75,17 @@ void IMAPMessage::setUid(uint32_t uid) mUid = uid; } +uint32_t IMAPMessage::size() +{ + return mSize; +} + +void IMAPMessage::setSize(uint32_t size) +{ + mSize = size; + +} + void IMAPMessage::setFlags(MessageFlag flags) { mFlags = flags; @@ -213,6 +224,7 @@ HashMap * IMAPMessage::serializable() HashMap * result = AbstractMessage::serializable(); result->setObjectForKey(MCSTR("modSeqValue"), String::stringWithUTF8Format("%llu", (long long unsigned) modSeqValue())); result->setObjectForKey(MCSTR("uid"), String::stringWithUTF8Format("%lu", (long unsigned) uid())); + result->setObjectForKey(MCSTR("size"), String::stringWithUTF8Format("%lu", (long unsigned) uid())); result->setObjectForKey(MCSTR("flags"), String::stringWithUTF8Format("%u", (unsigned) flags())); result->setObjectForKey(MCSTR("originalFlags"), String::stringWithUTF8Format("%u", (unsigned) originalFlags())); result->setObjectForKey(MCSTR("mainPart"), mMainPart->serializable()); @@ -239,6 +251,10 @@ void IMAPMessage::importSerializable(HashMap * serializable) if (uid != NULL) { setUid((uint32_t) uid->unsignedLongValue()); } + String * size = (String *) serializable->objectForKey(MCSTR("size")); + if (size != NULL) { + setSize((uint32_t) size->unsignedLongValue()); + } String * flags = (String *) serializable->objectForKey(MCSTR("flags")); if (flags != NULL) { setFlags((MessageFlag) flags->unsignedIntValue()); diff --git a/src/core/imap/MCIMAPMessage.h b/src/core/imap/MCIMAPMessage.h index 435334c7..d01d23a1 100644 --- a/src/core/imap/MCIMAPMessage.h +++ b/src/core/imap/MCIMAPMessage.h @@ -23,6 +23,9 @@ namespace mailcore { virtual uint32_t uid(); virtual void setUid(uint32_t uid); + virtual uint32_t size(); + virtual void setSize(uint32_t size); + virtual void setFlags(MessageFlag flags); virtual MessageFlag flags(); @@ -63,6 +66,8 @@ namespace mailcore { private: uint64_t mModSeqValue; uint32_t mUid; + uint32_t mSize; + MessageFlag mFlags; MessageFlag mOriginalFlags; AbstractPart * mMainPart; diff --git a/src/core/imap/MCIMAPSearchExpression.cc b/src/core/imap/MCIMAPSearchExpression.cc index 4e6b6e4e..0aa791d0 100644 --- a/src/core/imap/MCIMAPSearchExpression.cc +++ b/src/core/imap/MCIMAPSearchExpression.cc @@ -241,6 +241,22 @@ IMAPSearchExpression * IMAPSearchExpression::searchSinceReceivedDate(time_t date return (IMAPSearchExpression *) expr->autorelease(); } +IMAPSearchExpression * IMAPSearchExpression::searchSizeLarger(uint32_t size) +{ + IMAPSearchExpression * expr = new IMAPSearchExpression(); + expr->mKind = IMAPSearchKindSizeLarger; + expr->mNumber = size; + return (IMAPSearchExpression *) expr->autorelease(); +} + +IMAPSearchExpression * IMAPSearchExpression::searchSizeSmaller(uint32_t size) +{ + IMAPSearchExpression * expr = new IMAPSearchExpression(); + expr->mKind = IMAPSearchKindSizeSmaller; + expr->mNumber = size; + return (IMAPSearchExpression *) expr->autorelease(); +} + IMAPSearchExpression * IMAPSearchExpression::searchGmailThreadID(uint64_t number) { IMAPSearchExpression * expr = new IMAPSearchExpression(); @@ -287,6 +303,11 @@ uint64_t IMAPSearchExpression::longNumber() return mLongNumber; } +uint32_t IMAPSearchExpression::number() +{ + return mNumber; +} + time_t IMAPSearchExpression::date() { return mDate; diff --git a/src/core/imap/MCIMAPSearchExpression.h b/src/core/imap/MCIMAPSearchExpression.h index 13d934bc..6d313730 100644 --- a/src/core/imap/MCIMAPSearchExpression.h +++ b/src/core/imap/MCIMAPSearchExpression.h @@ -18,6 +18,7 @@ namespace mailcore { virtual String * header(); virtual String * value(); virtual uint64_t longNumber(); + virtual uint32_t number(); virtual time_t date(); virtual IMAPSearchExpression * leftExpression(); virtual IMAPSearchExpression * rightExpression(); @@ -44,7 +45,9 @@ namespace mailcore { static IMAPSearchExpression * searchBeforeReceivedDate(time_t date); static IMAPSearchExpression * searchOnReceivedDate(time_t date); static IMAPSearchExpression * searchSinceReceivedDate(time_t date); - static IMAPSearchExpression * searchGmailThreadID(uint64_t number); + static IMAPSearchExpression * searchSizeLarger(uint32_t number); + static IMAPSearchExpression * searchSizeSmaller(uint32_t size); + static IMAPSearchExpression * searchGmailThreadID(uint64_t size); static IMAPSearchExpression * searchAnd(IMAPSearchExpression * left, IMAPSearchExpression * right); static IMAPSearchExpression * searchOr(IMAPSearchExpression * left, IMAPSearchExpression * right); @@ -58,6 +61,7 @@ namespace mailcore { String * mHeader; String * mValue; uint64_t mLongNumber; + uint32_t mNumber; time_t mDate; IMAPSearchExpression * mLeftExpression; IMAPSearchExpression * mRightExpression; diff --git a/src/core/imap/MCIMAPSession.cc b/src/core/imap/MCIMAPSession.cc index 0a115e78..009bdc9f 100755 --- a/src/core/imap/MCIMAPSession.cc +++ b/src/core/imap/MCIMAPSession.cc @@ -1979,6 +1979,8 @@ static void msg_att_handler(struct mailimap_msg_att * msg_att, void * context) att_static = att_item->att_data.att_static; if (att_static->att_type == MAILIMAP_MSG_ATT_INTERNALDATE) { msg->header()->importIMAPInternalDate(att_static->att_data.att_internal_date); + } else if (att_static->att_type == MAILIMAP_MSG_ATT_RFC822_SIZE) { + msg->setSize(att_static->att_data.att_rfc822_size); } } } @@ -2153,6 +2155,13 @@ IMAPSyncResult * IMAPSession::fetchMessages(String * folder, IMAPMessagesRequest mailimap_fetch_type_new_fetch_att_list_add(fetch_type, fetch_att); needsHeader = true; } + if ((requestKind & IMAPMessagesRequestKindSize) != 0) { + // message structure + MCLog("request size"); + fetch_att = mailimap_fetch_att_new_rfc822_size(); + mailimap_fetch_type_new_fetch_att_list_add(fetch_type, fetch_att); + } + if ((requestKind & IMAPMessagesRequestKindStructure) != 0) { // message structure MCLog("request bodystructure"); @@ -2730,6 +2739,14 @@ static struct mailimap_search_key * searchKeyFromSearchExpression(IMAPSearchExpr NULL, NULL, NULL, NULL, NULL, NULL, 0, NULL, NULL, NULL); } + case IMAPSearchKindSizeLarger: + { + return mailimap_search_key_new_larger(expression->number()); + } + case IMAPSearchKindSizeSmaller: + { + return mailimap_search_key_new_smaller(expression->number()); + } case IMAPSearchKindOr: { return mailimap_search_key_new_or(searchKeyFromSearchExpression(expression->leftExpression()), searchKeyFromSearchExpression(expression->rightExpression())); |