summaryrefslogtreecommitdiff
path: root/program/include/rcmail.php
diff options
context:
space:
mode:
authorthomascube <thomas@roundcube.net>2008-06-07 11:22:59 +0000
committerthomascube <thomas@roundcube.net>2008-06-07 11:22:59 +0000
commit235086c7dec474eea538822386c093cf9e1fb93e (patch)
treef96327b1ac7bd0aa9e043ecfec502347f139153c /program/include/rcmail.php
parent6444cf4b29d29f16ef20513a80898f4db0c3a8c4 (diff)
Cleaned up localization names to unique language_COUNTRY schema according to ISO 639-1 and ISO 3166-1
Diffstat (limited to 'program/include/rcmail.php')
-rw-r--r--program/include/rcmail.php14
1 files changed, 11 insertions, 3 deletions
diff --git a/program/include/rcmail.php b/program/include/rcmail.php
index 5b8e74cdf..b01e5fd2b 100644
--- a/program/include/rcmail.php
+++ b/program/include/rcmail.php
@@ -186,10 +186,18 @@ class rcmail
if (!isset($rcube_languages[$lang]) && isset($rcube_language_aliases[$lang])) {
$lang = $rcube_language_aliases[$lang];
}
-
+
// try the first two chars
- if (!isset($rcube_languages[$lang]) && strlen($lang)>2) {
- $lang = $this->language_prop(substr($lang, 0, 2));
+ else if (!isset($rcube_languages[$lang]) && strlen($lang) > 2) {
+ $short = $this->language_prop(substr($lang, 0, 2));
+
+ // check if we have an alias for the short language code
+ if (!isset($rcube_languages[$short]) && isset($rcube_language_aliases[$short])) {
+ $lang = $rcube_language_aliases[$short];
+ }
+ else { // expand 'de' to 'de_DE'
+ $lang = $short.'_'.strtoupper($short);
+ }
}
if (!isset($rcube_languages[$lang]) || !is_dir(INSTALL_PATH . 'program/localization/' . $lang)) {