X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fi18n.php;h=2ce053dc8711d911a6f2f1440282f2cbfd75c1c5;hb=0d15cd1991b01408b96bfd7699dba4f4cee39df9;hp=0ef349b983831cf2d66aae46af20c42241f65f84;hpb=73d9de4e9a2d07fcb9725c8ee62691301ddb2126;p=squirrelmail.git diff --git a/functions/i18n.php b/functions/i18n.php index 0ef349b9..2ce053dc 100644 --- a/functions/i18n.php +++ b/functions/i18n.php @@ -20,18 +20,15 @@ if (! isset($squirrelmail_language)) { $squirrelmail_language = ''; } // This array specifies the available languages. - $languages['en']['NAME'] = 'English'; - $languages['en']['CHARSET'] = 'iso-8859-1'; - $languages['en_EN']['ALIAS'] = 'en'; - $languages['ca']['NAME'] = 'Catalan'; $languages['ca']['CHARSET'] = 'iso-8859-1'; $languages['ca_CA']['ALIAS'] = 'ca'; - $languages['hr']['NAME'] = 'Croatian'; - $languages['hr']['CHARSET'] = 'iso-8859-2'; - $languages['hr_HR']['ALIAS'] = 'hr'; - + /* PLEASE DON'T TOUCH!!! + * Correct locale name, which should be set by setlocale and/or putenv('LC_ALL='...) + * is 'cs_CZ' and NOT 'cs', this applies to all locale names, look into docs, if you + * don't believe me. Ondrej Sury, czech and slovak translator. + */ $languages['cs_CZ']['NAME'] = 'Czech'; $languages['cs_CZ']['CHARSET'] = 'iso-8859-2'; @@ -43,26 +40,38 @@ $languages['de']['CHARSET'] = 'iso-8859-1'; $languages['de_DE']['ALIAS'] = 'de'; - $languages['id']['NAME'] = 'Indonesian'; - $languages['id']['CHARSET'] = 'iso-8859-1'; - $languages['id_ID']['ALIAS'] = 'id'; - - $languages['nl']['NAME'] = 'Dutch'; - $languages['nl']['CHARSET'] = 'iso-8859-1'; - $languages['nl_NL']['ALIAS'] = 'nl'; + $languages['en']['NAME'] = 'English'; + $languages['en']['CHARSET'] = 'iso-8859-1'; + $languages['en_EN']['ALIAS'] = 'en'; + $languages['es']['NAME'] = 'Spanish'; + $languages['es']['CHARSET'] = 'iso-8859-1'; + $languages['es_ES']['ALIAS'] = 'es'; + + $languages['et']['NAME'] = 'Estonian'; + $languages['et']['CHARSET'] = 'iso-8859-15'; + $languages['et_EE']['ALIAS'] = 'et'; + + $languages['fi']['NAME'] = 'Finnish'; + $languages['fi']['CHARSET'] = 'iso-8859-1'; + $languages['fi_FI']['ALIAS'] = 'fi'; + $languages['fr']['NAME'] = 'French'; $languages['fr']['CHARSET'] = 'iso-8859-1'; $languages['fr_FR']['ALIAS'] = 'fr'; - $languages['fi']['NAME'] = 'Finnish'; - $languages['fi']['CHARSET'] = 'iso-8859-1'; - $languages['fi_FI']['ALIAS'] = 'fi'; + $languages['hr']['NAME'] = 'Croatian'; + $languages['hr']['CHARSET'] = 'iso-8859-2'; + $languages['hr_HR']['ALIAS'] = 'hr'; $languages['hu']['NAME'] = 'Hungarian'; - $languages['hu']['CHARSET'] = 'iso-8859-1'; + $languages['hu']['CHARSET'] = 'iso-8859-2'; $languages['hu_HU']['ALIAS'] = 'hu'; + $languages['id']['NAME'] = 'Indonesian'; + $languages['id']['CHARSET'] = 'iso-8859-1'; + $languages['id_ID']['ALIAS'] = 'id'; + $languages['is']['NAME'] = 'Icelandic'; $languages['is']['CHARSET'] = 'iso-8859-1'; $languages['is_IS']['ALIAS'] = 'is'; @@ -73,25 +82,27 @@ $languages['ko']['NAME'] = 'Korean'; $languages['ko']['CHARSET'] = 'euc-KR'; - $languages['ko_KO']['CHARSET'] = 'ko'; + $languages['ko_KO']['ALIAS'] = 'ko'; + + $languages['nl']['NAME'] = 'Dutch'; + $languages['nl']['CHARSET'] = 'iso-8859-1'; + $languages['nl_NL']['ALIAS'] = 'nl'; $languages['no']['NAME'] = 'Norwegian (Bokmål)'; $languages['no']['CHARSET'] = 'iso-8859-1'; $languages['no_NO']['ALIAS'] = 'no'; - $languages['no_NO_ny']['NAME'] = 'Norwegian (Nynorsk)'; $languages['no_NO_ny']['CHARSET'] = 'iso-8859-1'; $languages['pl']['NAME'] = 'Polish'; $languages['pl']['CHARSET'] = 'iso-8859-2'; - $languages['pl_PL']['Alias'] = 'pl'; + $languages['pl_PL']['ALIAS'] = 'pl'; $languages['pt']['NAME'] = 'Português (Portugal)'; $languages['pt']['CHARSET'] = 'iso-8859-1'; - $languages['pt_PT']['CHARSET'] = 'pt'; - $languages['pt_BR']['NAME'] = 'Portuguese (Brazil)'; $languages['pt_BR']['CHARSET'] = 'iso-8859-1'; + $languages['pt_PT']['ALIAS'] = 'pt'; $languages['ru']['NAME'] = 'Russian KOI8-R'; $languages['ru']['CHARSET'] = 'koi8-r'; @@ -101,18 +112,31 @@ $languages['sr']['CHARSET'] = 'iso-8859-2'; $languages['sr_SR']['ALIAS'] = 'sr'; - $languages['es']['NAME'] = 'Spanish'; - $languages['es']['CHARSET'] = 'iso-8859-1'; - $languages['es_ES']['ALIAS'] = 'es'; - $languages['sv']['NAME'] = 'Swedish'; $languages['sv']['CHARSET'] = 'iso-8859-1'; $languages['sv_SV']['ALIAS'] = 'sv'; + $languages['tr']['NAME'] = 'Turkish'; + $languages['tr']['CHARSET'] = 'iso-8859-9'; + $languages['tr_TR']['ALIAS'] = 'tr'; + $languages['tw']['NAME'] = 'Taiwan'; $languages['tw']['CHARSET'] = 'big5'; $languages['tw_TW']['ALIAS'] = 'tw'; + $languages['sk_SK']['NAME'] = 'Slovak'; + $languages['sk_SK']['CHARSET'] = 'iso-8859-2'; + + $languages['ro']['NAME'] = 'Romanian'; + $languages['ro']['CHARSET'] = 'iso-8859-2'; + $languages['ro_RO']['ALIAS'] = 'ro'; + + $languages['th']['NAME'] = 'Thai'; + $languages['th']['CHARSET'] = 'tis-620'; + + $languages['lt']['NAME'] = 'Lithuanian'; + $languages['lt']['CHARSET'] = 'iso-8859-13'; + $languages['lt_LT']['ALIAS'] = 'lt'; // Decodes a string to the internal encoding from the given charset function charset_decode ($charset, $string) { @@ -140,6 +164,8 @@ return charset_decode_ns_4551_1 ($string); } else if ($charset == 'koi8-r') { return charset_decode_koi8r ($string); + } else if ($charset == 'windows-1251') { + return charset_decode_koi8r ($string); } else return $string; } @@ -297,7 +323,7 @@ // Only do the slow convert if there are 8-bit characters if (! ereg("[\200-\377]", $string)) return $string; - + // NO-BREAK SPACE $string = str_replace("\240", ' ', $string); // LATIN CAPITAL LETTER A WITH OGONEK @@ -500,11 +526,11 @@ if (strtolower($default_charset) == 'iso-8859-7') return $string; - + // Only do the slow convert if there are 8-bit characters if (!ereg("[\200-\377]", $string)) return $string; - + // Some diverse characters in the beginning $string = str_replace("\240", ' ', $string); $string = str_replace("\241", '‘', $string); @@ -540,7 +566,7 @@ // These are Unicode 900-902 while (ereg("([\270-\272])", $string, $res)) { $replace = '&#' . (ord($res[1])+720) . ";"; - $string = str_replace($res[1], $replace, $string); + $string = str_replace($res[1], $replace, $string); } // 11/11 (0xBB) Right angle quotation mark is the same as in @@ -550,7 +576,7 @@ // And now the rest of the charset while (ereg("([\274-\376])", $string, $res)) { $replace = '&#' . (ord($res[1])+720) . ';'; - $string = str_replace($res[1], $replace, $string); + $string = str_replace($res[1], $replace, $string); } return $string; @@ -625,7 +651,7 @@ if ($default_charset == 'koi8-r') return $string; - + // Convert to Unicode HTML entities. // This code is rather ineffective. $string = str_replace("\200", '─', $string); @@ -775,7 +801,7 @@ // If we can fake gettext, try that elseif ($gettext_flags == 0) { $use_gettext = true; - include('../functions/gettext.php'); + include_once('../functions/gettext.php'); } else { // Uh-ho. A weird install if (! $gettext_flags & 1) { @@ -793,12 +819,11 @@ // Set up the language to be output // if $do_search is true, then scan the browser information // for a possible language that we know - function set_up_language($sm_language, $do_search = false) - { + function set_up_language($sm_language, $do_search = false) { static $SetupAlready = 0; global $HTTP_ACCEPT_LANGUAGE, $use_gettext, $languages, $squirrelmail_language, $squirrelmail_default_language, - $sm_notAlias; + $sm_notAlias; if ($SetupAlready) return; @@ -810,15 +835,15 @@ if ($do_search && ! $sm_language && isset($HTTP_ACCEPT_LANGUAGE)) { $sm_language = substr($HTTP_ACCEPT_LANGUAGE, 0, 2); } - if (! $sm_language && isset($squirrelmail_default_language)) - $sm_language = $squirrelmail_default_language; + if (!$sm_language && isset($squirrelmail_default_language)) + $squirrelmail_language = $squirrelmail_default_language; $sm_notAlias = $sm_language; while (isset($languages[$sm_notAlias]['ALIAS'])) $sm_notAlias = $languages[$sm_notAlias]['ALIAS']; if (isset($sm_language) && $use_gettext && - $squirrelmail_language != '' && - isset($languages[$sm_notAlias]['CHARSET'])) { + $sm_language != '' && + isset($languages[$sm_notAlias]['CHARSET'])) { if ((ini_get('safe_mode') == FALSE) && (getenv('LC_ALL') != $sm_language)) { putenv('LC_ALL=' . $sm_notAlias); } @@ -848,4 +873,4 @@ if ($my_charset) $default_charset=$my_charset; } -?> +?> \ No newline at end of file