From 4a63f1efaff83dd03e663ed1a432a15dc0100be3 Mon Sep 17 00:00:00 2001 From: alecpl Date: Mon, 7 Sep 2009 07:53:01 +0000 Subject: - Fix roundcube hangs on empty inbox with bincimapd (#1486093) --- program/include/rcube_imap.php | 6 ++++-- program/lib/imap.inc | 10 +++++----- 2 files changed, 9 insertions(+), 7 deletions(-) (limited to 'program') diff --git a/program/include/rcube_imap.php b/program/include/rcube_imap.php index 3d8cb84b8..f1729311b 100644 --- a/program/include/rcube_imap.php +++ b/program/include/rcube_imap.php @@ -2228,8 +2228,10 @@ class rcube_imap $msg_count = $this->_messagecount($mailbox); $cache_count = count($cache_index); - // console("Cache check: $msg_count !== ".count($cache_index)); - + // empty mailbox + if (!$msg_count) + return $cache_count ? -2 : 1; + if ($cache_count==$msg_count) { if ($this->skip_deleted) { $h_index = iil_C_FetchHeaderIndex($this->conn, $mailbox, "1:*", 'UID', $this->skip_deleted); diff --git a/program/lib/imap.inc b/program/lib/imap.inc index 02c9bd9b5..c640c56e4 100644 --- a/program/lib/imap.inc +++ b/program/lib/imap.inc @@ -1510,11 +1510,11 @@ function iil_C_FetchHeaders(&$conn, $mailbox, $message_set, $uidfetch=false, $bo preg_match('/ BODY\[HEADER.FIELDS \(.*?\)\]\s*(.*)$/s', $line, $m); $reslines = explode("\n", trim($m[1], '"')); // re-parse (see below) - foreach ($reslines as $line) { - if (ord($line[0])<=32) { - $lines[$ln] .= (empty($lines[$ln])?'':"\n").trim($line); + foreach ($reslines as $resln) { + if (ord($resln[0])<=32) { + $l[$ln] .= (empty($lines[$ln])?'':"\n").trim($resln); } else { - $lines[++$ln] = trim($line); + $lines[++$ln] = trim($resln); } } } @@ -1668,7 +1668,7 @@ function iil_C_FetchHeaders(&$conn, $mailbox, $message_set, $uidfetch=false, $bo } } } - } while (strcmp($a[0], $key) != 0); + } while (!iil_StartsWith($line, $key, true)); return $result; } -- cgit v1.2.3