imap: Added skipping of SELECT command if already in the same mailbox

Added storage and checking of the last mailbox userd to prevent
unnecessary switching.
This commit is contained in:
Jiri Hruska
2013-02-27 19:02:53 +01:00
committed by Steve Holme
parent d03aa16164
commit b644c47192

View File

@@ -674,7 +674,8 @@ static CURLcode imap_select(struct connectdata *conn)
struct imap_conn *imapc = &conn->proto.imapc; struct imap_conn *imapc = &conn->proto.imapc;
char *mailbox; char *mailbox;
/* Invalidate old information in case we are switching mailboxes */ /* Invalidate old information as we are switching mailboxes */
Curl_safefree(imapc->mailbox);
Curl_safefree(imapc->mailbox_uidvalidity); Curl_safefree(imapc->mailbox_uidvalidity);
mailbox = imap_atom(imap->mailbox ? imap->mailbox : ""); mailbox = imap_atom(imap->mailbox ? imap->mailbox : "");
@@ -1241,9 +1242,13 @@ static CURLcode imap_state_select_resp(struct connectdata *conn,
failf(conn->data, "Mailbox UIDVALIDITY has changed"); failf(conn->data, "Mailbox UIDVALIDITY has changed");
result = CURLE_REMOTE_FILE_NOT_FOUND; result = CURLE_REMOTE_FILE_NOT_FOUND;
} }
else else {
/* Note the currently opened mailbox on this connection */
imapc->mailbox = strdup(imap->mailbox);
result = imap_fetch(conn); result = imap_fetch(conn);
} }
}
return result; return result;
} }
@@ -1592,6 +1597,9 @@ static CURLcode imap_perform(struct connectdata *conn, bool *connected,
{ {
/* This is IMAP and no proxy */ /* This is IMAP and no proxy */
CURLcode result = CURLE_OK; CURLcode result = CURLE_OK;
struct SessionHandle *data = conn->data;
struct IMAP *imap = data->state.proto.imap;
struct imap_conn *imapc = &conn->proto.imapc;
DEBUGF(infof(conn->data, "DO phase starts\n")); DEBUGF(infof(conn->data, "DO phase starts\n"));
@@ -1604,7 +1612,17 @@ static CURLcode imap_perform(struct connectdata *conn, bool *connected,
*dophase_done = FALSE; /* not done yet */ *dophase_done = FALSE; /* not done yet */
/* Start the first command in the DO phase */ /* Start the first command in the DO phase */
if(imap->mailbox && imapc->mailbox &&
!strcmp(imap->mailbox, imapc->mailbox) &&
(!imap->uidvalidity || !imapc->mailbox_uidvalidity ||
!strcmp(imap->uidvalidity, imapc->mailbox_uidvalidity))) {
/* This mailbox (with the same UIDVALIDITY if set) is already selected on
this connection so go straight to the next fetch operation */
result = imap_fetch(conn);
}
else
result = imap_select(conn); result = imap_select(conn);
if(result) if(result)
return result; return result;