X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=imap%2Fimap.c;h=0ad54d1ead48eda4e8bcd86d35f69dc3ef3227ad;hb=f07b807db70d3ac5d0a8086819cfbb4f7ff25f07;hp=d444b410e8b80830f138dd22c23c31f095efa675;hpb=faed98ab64dd3cbd29e674141cd074d6c9f8909c;p=apps%2Fmadmutt.git diff --git a/imap/imap.c b/imap/imap.c index d444b41..0ad54d1 100644 --- a/imap/imap.c +++ b/imap/imap.c @@ -606,6 +606,17 @@ int imap_open_mailbox (CONTEXT* ctx) if ((pc = imap_get_flags (&(idata->flags), pc)) == NULL) goto fail; } +#ifdef USE_HCACHE + /* save UIDVALIDITY for the header cache */ + else if (ascii_strncasecmp("OK [UIDVALIDITY", pc, 14) == 0) + { + dprint(2, (debugfile, "Getting mailbox UIDVALIDITY\n")); + pc += 3; + pc = imap_next_word(pc); + + sscanf(pc, "%u", &(idata->uid_validity)); + } +#endif else { pc = imap_next_word (pc); @@ -1473,3 +1484,21 @@ int imap_complete(char* dest, size_t dlen, char* path) { FREE (&mx.mbox); return -1; } + +/* reconnect and verify indexes if connection was lost */ +int imap_reconnect(CONTEXT* ctx) { + IMAP_DATA* imap_data = (IMAP_DATA *)ctx->data; + + if (imap_data->status == IMAP_CONNECTED) + return -1; + if (imap_data->status == IMAP_BYE) + return 0; + + mutt_socket_close(imap_data->conn); + + if (query_quadoption(OPT_IMAPRECONNECT,_("Connection lost. Reconnect to IMAP server?")) != M_YES) + return -1; + + return imap_open_mailbox(ctx); +} +