From: Guilhem Moulin Date: Tue, 22 Nov 2016 18:41:46 +0000 (+0100) Subject: bugfix: when resuming a sync, only consider UIDs greater than a known UIDNEXT. X-Git-Url: https://git.g-eek.se/?a=commitdiff_plain;h=986edff592c159cb9057e960f380057ff06da939;p=interimap.git bugfix: when resuming a sync, only consider UIDs greater than a known UIDNEXT. --- diff --git a/interimap b/interimap index eccd3ab..7a36c4e 100755 --- a/interimap +++ b/interimap @@ -1088,6 +1088,18 @@ while (defined (my $row = $STH_LIST_INTERRUPTED->fetchrow_arrayref())) { # the _MODIFIED internal cache has been initialized with all our # UIDs. (Since there is no reliable HIGHESTMODSEQ, any flag # difference is treated as a conflict.) + $STH_GET_CACHE_BY_IDX->execute($IDX); + if (defined (my $cache = $STH_GET_CACHE_BY_IDX->fetchrow_hashref())) { + $lIMAP->set_cache($cache->{mailbox}, + UIDVALIDITY => $cache->{lUIDVALIDITY}, + UIDNEXT => $cache->{lUIDNEXT} + ); + $rIMAP->set_cache($cache->{mailbox}, + UIDVALIDITY => $cache->{rUIDVALIDITY}, + UIDNEXT => $cache->{rUIDNEXT} + ); + die if defined $STH_GET_CACHE_BY_IDX->fetch(); # sanity check + } sync_messages($IDX, $MAILBOX, [keys %lList], [keys %rList]); }