+/**
+ * Recursively walk the tree of trash mailboxes and delete all folders and messages
+ *
+ * @param int index the place in the tree to start, usually 0
+ * @param stream imap_stream the IMAP connection to send commands to
+ * @param array tree the tree to walk
+ * @return void
+ */
+function walkTreeInPreOrderEmptyTrash($index, $imap_stream, $tree) {
+ global $trash_folder;
+ if ($tree[$index]['doIHaveChildren']) {
+ for ($j = 0; $j < count($tree[$index]['subNodes']); $j++) {
+ walkTreeInPreOrderEmptyTrash($tree[$index]['subNodes'][$j], $imap_stream, $tree);
+ }
+ if ($tree[$index]['value'] != $trash_folder) {
+ sqimap_mailbox_delete($imap_stream, $tree[$index]['value']);
+ } else {
+ $mbx_response = sqimap_mailbox_select($imap_stream, $trash_folder);
+ if ($mbx_response['EXISTS'] > 0) {
+ sqimap_messages_flag ($imap_stream, 1, '*', 'Deleted', true);
+ // CLOSE === EXPUNGE and UNSELECT
+ sqimap_run_command($imap_stream,'CLOSE',false,$response,$message);
+ }
+ }
+ } else {
+ if ($tree[$index]['value'] != $trash_folder) {
+ sqimap_mailbox_delete($imap_stream, $tree[$index]['value']);
+ } else {
+ $mbx_response = sqimap_mailbox_select($imap_stream, $trash_folder);
+ if ($mbx_response['EXISTS'] > 0) {
+ sqimap_messages_flag ($imap_stream, 1, '*', 'Deleted', true);
+ // CLOSE === EXPUNGE and UNSELECT
+ sqimap_run_command($imap_stream,'CLOSE',false,$response,$message);
+ }
+ }
+ }
+}