summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2009-06-17 18:01:07 +0000
committeralecpl <alec@alec.pl>2009-06-17 18:01:07 +0000
commit28674a848ab4974eccf952dfe2271a80e4d536c4 (patch)
tree7a3fcae437e3e9d5aba0c39499ec91aa858aa8ea
parent14f1c0fce20f21d27b0c1421344e13f3e89fb87c (diff)
- fix bug in delete_mailbox when deleting many folders
-rw-r--r--program/include/rcube_imap.php17
1 files changed, 9 insertions, 8 deletions
diff --git a/program/include/rcube_imap.php b/program/include/rcube_imap.php
index e7f72ee13..7905894e1 100644
--- a/program/include/rcube_imap.php
+++ b/program/include/rcube_imap.php
@@ -1963,7 +1963,7 @@ class rcube_imap
/**
* Remove mailboxes from server
*
- * @param string Mailbox name
+ * @param string Mailbox name(s) string/array
* @return boolean True on success
*/
function delete_mailbox($mbox_name)
@@ -1987,9 +1987,11 @@ class rcube_imap
// send delete command to server
$result = iil_C_DeleteFolder($this->conn, $mailbox);
- if ($result>=0)
+ if ($result >= 0) {
$deleted = TRUE;
-
+ $this->clear_message_cache($mailbox.'.msg');
+ }
+
foreach ($all_mboxes as $c_mbox)
{
$regex = preg_quote($mailbox . $this->delimiter, '/');
@@ -1998,18 +2000,17 @@ class rcube_imap
{
iil_C_UnSubscribe($this->conn, $c_mbox);
$result = iil_C_DeleteFolder($this->conn, $c_mbox);
- if ($result>=0)
+ if ($result >= 0) {
$deleted = TRUE;
- }
+ $this->clear_message_cache($c_mbox.'.msg');
+ }
+ }
}
}
// clear mailboxlist cache
if ($deleted)
- {
- $this->clear_message_cache($mailbox.'.msg');
$this->clear_cache('mailboxes');
- }
return $deleted;
}