Don't solely rely on the presence of RECENT for checking for new mail.

It may happen (depending on server and/or timing) that only an EXISTS
response is sent to the IDLE connection when new mail arrives. Don't
discard that response, but evaluate it to determine whether there's new
mail by checking whether the message count increased.

Change-Id: Ia49714e6cd42dd71dfda8b7bbdf1fd622972edda
This commit is contained in:
Danny Baumann 2015-06-09 12:54:00 +02:00 committed by Steve Kondik
parent d13071399f
commit 006ea81b71

View File

@ -548,8 +548,10 @@ public class ImapFolder extends Folder {
@Override @Override
public int getMessageCount() { public int getMessageCount() {
synchronized (this) {
return mMessageCount; return mMessageCount;
} }
}
@Override @Override
public int getUnreadMessageCount() throws MessagingException { public int getUnreadMessageCount() throws MessagingException {
@ -1103,9 +1105,11 @@ public class ImapFolder extends Folder {
*/ */
private void handleUntaggedResponse(ImapResponse response) { private void handleUntaggedResponse(ImapResponse response) {
if (response.isDataResponse(1, ImapConstants.EXISTS)) { if (response.isDataResponse(1, ImapConstants.EXISTS)) {
synchronized (this) {
mMessageCount = response.getStringOrEmpty(0).getNumberOrZero(); mMessageCount = response.getStringOrEmpty(0).getNumberOrZero();
} }
} }
}
private static void parseBodyStructure(ImapList bs, Part part, String id) private static void parseBodyStructure(ImapList bs, Part part, String id)
throws MessagingException { throws MessagingException {
@ -1541,9 +1545,10 @@ public class ImapFolder extends Folder {
// OK DONE // OK DONE
// No more changes // No more changes
// n EXISTS // n EXISTS
// Indicates that the mailbox changed => ignore // Indicates the number of messages in the mailbox => handle like
// RECENT if the number increased
// n EXPUNGE // n EXPUNGE
// Indicates a message were completely deleted => a full sync is required // Indicates a message was completely deleted => a full sync is required
// n RECENT // n RECENT
// New messages waiting in the server => use UIDNEXT to search for the new messages. // New messages waiting in the server => use UIDNEXT to search for the new messages.
// If isn't possible to retrieve the new UID messages, then a full sync is required // If isn't possible to retrieve the new UID messages, then a full sync is required
@ -1587,9 +1592,24 @@ public class ImapFolder extends Folder {
if (op.is(ImapConstants.DONE)) { if (op.is(ImapConstants.DONE)) {
break; break;
} else if (op.is(ImapConstants.EXISTS)) { } else if (op.is(ImapConstants.EXISTS)) {
continue; int newMessageCount = change.getStringOrEmpty(0).getNumberOrZero();
int oldMessageCount;
synchronized (this) {
oldMessageCount = mMessageCount;
mMessageCount = newMessageCount;
}
if (Logging.LOGD) {
LogUtils.d(LOG_TAG, "Got EXISTS idle response, message count now "
+ newMessageCount + ", was " + oldMessageCount);
}
if (newMessageCount > oldMessageCount) {
hasNewMessages = true;
}
} else if (op.is(ImapConstants.EXPUNGE)) { } else if (op.is(ImapConstants.EXPUNGE)) {
imapIdleChanges.mRequiredSync = true; imapIdleChanges.mRequiredSync = true;
synchronized (this) {
mMessageCount--;
}
} else if (op.is(ImapConstants.RECENT)) { } else if (op.is(ImapConstants.RECENT)) {
hasNewMessages = true; hasNewMessages = true;
} else if (op.is(ImapConstants.FETCH) } else if (op.is(ImapConstants.FETCH)