X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fimap_search.php;h=38832fc1be862cc1af0ec8fc60ea3d7ac8b743cb;hb=5d55b3d5a8aa567b2a9fb2d53d317976dc6cce5a;hp=3c253584a54e51270e2f613395b4f1c80add7189;hpb=20473d1e46b52f35bb6948d312f6b87a21dc07f1;p=squirrelmail.git diff --git a/functions/imap_search.php b/functions/imap_search.php index 3c253584..38832fc1 100644 --- a/functions/imap_search.php +++ b/functions/imap_search.php @@ -3,7 +3,7 @@ /** * imap_search.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2003 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * IMAP search routines @@ -11,17 +11,17 @@ * $Id$ */ -require_once('../functions/imap.php'); -require_once('../functions/date.php'); -require_once('../functions/array.php'); -require_once('../functions/mailbox_display.php'); -require_once('../functions/mime.php'); +require_once(SM_PATH . 'functions/imap.php'); +require_once(SM_PATH . 'functions/date.php'); +require_once(SM_PATH . 'functions/mailbox_display.php'); +require_once(SM_PATH . 'functions/mime.php'); function sqimap_search($imapConnection, $search_where, $search_what, $mailbox, $color, $search_position = '', $search_all, $count_all) { global $message_highlight_list, $squirrelmail_language, $languages, - $index_order, $pos, $allow_charset_search, $uid_support; + $index_order, $pos, $allow_charset_search, $uid_support, + $imap_server_type; $pos = $search_position; @@ -33,9 +33,31 @@ function sqimap_search($imapConnection, $search_where, $search_what, $mailbox, $search_what = ereg_replace('[ ]{2,}', ' ', $search_what); $multi_search = explode(' ', $search_what); $search_string = ''; - foreach ($multi_search as $multi_search_part) { - $search_string .= $search_where . ' {' . strlen($multi_search_part) - . "}\r\n" . $multi_search_part . ' '; + + /* it seems macosx does not support the prefered search + syntax so we fall back to the older style. This IMAP + server has a problem with multiple search terms. Instead + of returning the messages that match all the terms it + returns the messages that match each term. Could be fixed + on the client side, but should be fixed on the server + as per the RFC */ + + if ($imap_server_type == 'macosx') { + foreach ($multi_search as $multi_search_part) { + if (strtoupper($languages[$squirrelmail_language]['CHARSET']) == 'ISO-2022-JP') { + $multi_search_part = mb_convert_encoding($multi_search_part, 'JIS', 'auto'); + } + $search_string .= $search_where . ' ' .$multi_search_part . ' '; + } + } + else { + foreach ($multi_search as $multi_search_part) { + if (strtoupper($languages[$squirrelmail_language]['CHARSET']) == 'ISO-2022-JP') { + $multi_search_part = mb_convert_encoding($multi_search_part, 'JIS', 'auto'); + } + $search_string .= $search_where . ' {' . strlen($multi_search_part) + . "}\r\n" . $multi_search_part . ' '; + } } $search_string = trim($search_string); @@ -80,7 +102,7 @@ function sqimap_search($imapConnection, $search_where, $search_what, $mailbox, if (strstr($errors,'* SEARCH')) { return array(); } - echo ""; + echo ''; }