]> granicus.if.org Git - mutt/commitdiff
Add polling for the IDLE command. (closes #3957)
authorKevin McCarthy <kevin@8t8.us>
Sun, 15 Oct 2017 07:13:18 +0000 (15:13 +0800)
committerKevin McCarthy <kevin@8t8.us>
Sun, 15 Oct 2017 07:13:18 +0000 (15:13 +0800)
Add $imap_poll_timeout poll for IDLE, since this is also a command
that will freeze after waking if $imap_idle is set.

imap/command.c

index 3c10468155fed78f1c1442faa8ae23158c273196..41b4bee694206c0aa6a22aa6c0ba09b2c0f2ff66 100644 (file)
@@ -333,7 +333,21 @@ int imap_cmd_idle (IMAP_DATA* idata)
 {
   int rc;
 
-  imap_cmd_start (idata, "IDLE");
+  if (cmd_start (idata, "IDLE", IMAP_CMD_POLL) < 0)
+  {
+    cmd_handle_fatal (idata);
+    return -1;
+  }
+
+  if ((ImapPollTimeout > 0) &&
+      (mutt_socket_poll (idata->conn, ImapPollTimeout)) == 0)
+  {
+    mutt_error (_("Connection to %s timed out"), idata->conn->account.host);
+    mutt_sleep (2);
+    cmd_handle_fatal (idata);
+    return -1;
+  }
+
   do
     rc = imap_cmd_step (idata);
   while (rc == IMAP_CMD_CONTINUE);