2 /* vim: set expandtab sw=4 ts=4 sts=4: */
4 * phpMyAdmin Language Loading File
8 if (! defined('PHPMYADMIN')) {
13 * Returns language name
15 * @param string $tmplang
19 function PMA_langName($tmplang)
21 $lang_name = ucfirst(substr(strrchr($tmplang[0], '|'), 1));
23 // Include native name if non empty
24 if (!empty($tmplang[2])) {
25 $lang_name = $tmplang[2] . ' - ' . $lang_name;
32 * Tries to find the language to use
34 * @return bool success if valid lang is found, otherwise false
36 function PMA_langCheck()
38 // check forced language
39 if (! empty($GLOBALS['cfg']['Lang'])) {
40 if (PMA_langSet($GLOBALS['cfg']['Lang'])) {
43 $GLOBALS['lang_failed_cfg'] = $GLOBALS['cfg']['Lang'];
47 // Don't use REQUEST in following code as it might be confused by cookies
48 // with same name. Check user requested language (POST)
49 if (! empty($_POST['lang'])) {
50 if (PMA_langSet($_POST['lang'])) {
52 } elseif (!is_string($_POST['lang'])) {
53 /* Faked request, don't care on localisation */
54 $GLOBALS['lang_failed_request'] = 'Yes';
56 $GLOBALS['lang_failed_request'] = $_POST['lang'];
60 // check user requested language (GET)
61 if (! empty($_GET['lang'])) {
62 if (PMA_langSet($_GET['lang'])) {
64 } elseif (!is_string($_GET['lang'])) {
65 /* Faked request, don't care on localisation */
66 $GLOBALS['lang_failed_request'] = 'Yes';
68 $GLOBALS['lang_failed_request'] = $_GET['lang'];
72 // check previous set language
73 if (! empty($_COOKIE['pma_lang'])) {
74 if (PMA_langSet($_COOKIE['pma_lang'])) {
76 } elseif (!is_string($_COOKIE['pma_lang'])) {
77 /* Faked request, don't care on localisation */
78 $GLOBALS['lang_failed_cookie'] = 'Yes';
80 $GLOBALS['lang_failed_cookie'] = $_COOKIE['pma_lang'];
84 // try to find out user's language by checking its HTTP_ACCEPT_LANGUAGE variable;
86 $accepted_languages = PMA_getenv('HTTP_ACCEPT_LANGUAGE');
87 if ($accepted_languages && false === strpos($accepted_languages, '<')) {
88 foreach (explode(',', $accepted_languages) as $lang) {
89 if (PMA_langDetect($lang, 1)) {
94 unset($accepted_languages);
96 // try to find out user's language by checking its HTTP_USER_AGENT variable
97 if (PMA_langDetect(PMA_getenv('HTTP_USER_AGENT'), 2)) {
101 // Didn't catch any valid lang : we use the default settings
102 if (PMA_langSet($GLOBALS['cfg']['DefaultLang'])) {
110 * checks given lang and sets it if valid
111 * returns true on success, otherwise false
113 * @param string &$lang language to set
115 * @return bool success
117 function PMA_langSet(&$lang)
119 /* Partial backward compatibility with 3.3 and older branches */
120 $lang = str_replace('-utf-8', '', $lang);
122 if (!is_string($lang) ||
empty($lang) ||
empty($GLOBALS['available_languages'][$lang])) {
125 $GLOBALS['lang'] = $lang;
130 * Analyzes some PHP environment variables to find the most probable language
131 * that should be used
133 * @param string $str string to analyze
134 * @param integer $envType type of the PHP environment variable which value is $str
136 * @return bool true on success, otherwise false
140 function PMA_langDetect($str, $envType)
145 if (empty($GLOBALS['available_languages'])) {
149 foreach ($GLOBALS['available_languages'] as $lang => $value) {
150 // $envType = 1 for the 'HTTP_ACCEPT_LANGUAGE' environment variable,
151 // 2 for the 'HTTP_USER_AGENT' one
153 if (strpos($expr, '[-_]') === false) {
154 $expr = str_replace('|', '([-_][[:alpha:]]{2,3})?|', $expr);
156 if (($envType == 1 && preg_match('/^(' . addcslashes($expr, '/') . ')(;q=[0-9]\\.[0-9])?$/i', $str))
157 ||
($envType == 2 && preg_match('/(\(|\[|;[[:space:]])(' . addcslashes($expr, '/') . ')(;|\]|\))/i', $str))
159 if (PMA_langSet($lang)) {
166 } // end of the 'PMA_langDetect()' function
170 * All the supported languages have to be listed in the array below.
171 * 1. The key must be the "official" ISO 639 language code and, if required,
172 * the dialect code. It can also contain some information about the
173 * charset (see the Russian case).
174 * 2. The first of the values associated to the key is used in a regular
175 * expression to find some keywords corresponding to the language inside two
176 * environment variables.
177 * These values contain:
178 * - the "official" ISO language code and, if required, the dialect code
179 * too ('bu' for Bulgarian, 'fr([-_][[:alpha:]]{2})?' for all French
180 * dialects, 'zh[-_]tw' for Chinese traditional...), the dialect has to
181 * be specified first;
182 * - the '|' character (it means 'OR');
183 * - the full language name.
184 * 3. The second value associated to the key is the language code as defined by
186 * 4. The third value is its native name in html entities or UTF-8.
188 * Beware that the sorting order (first values associated to keys by
189 * alphabetical reverse order in the array) is important: 'zh-tw' (chinese
190 * traditional) must be detected before 'zh' (chinese simplified) for
193 * @param string $lang language
197 function PMA_langDetails($lang)
201 return array('af|afrikaans', 'af', '');
203 return array('ar|arabic', 'ar', 'العربية');
205 return array('az|azerbaijani', 'az', 'Azərbaycanca');
207 return array('bn|bangla', 'bn', 'বাংলা');
209 return array('be|belarusian', 'be', 'Беларуская');
211 return array('be[-_]lat|belarusian latin', 'be-lat', 'Biełaruskaja');
213 return array('bg|bulgarian', 'bg', 'Български');
215 return array('bs|bosnian', 'bs', 'Bosanski');
217 return array('br|breton', 'br', 'Brezhoneg');
219 return array('ca|catalan', 'ca', 'Català');
221 return array('ckb', 'ckb', 'سۆرانی');
223 return array('cs|czech', 'cs', 'Čeština');
225 return array('cy|welsh', 'cy', 'Cymraeg');
227 return array('da|danish', 'da', 'Dansk');
229 return array('de|german', 'de', 'Deutsch');
231 return array('el|greek', 'el', 'Ελληνικά');
233 return array('en|english', 'en', '');
235 return array('en[_-]gb|english (United Kingdom)', 'en-gb', '');
237 return array('es|spanish', 'es', 'Español');
239 return array('et|estonian', 'et', 'Eesti');
241 return array('eu|basque', 'eu', 'Euskara');
243 return array('fa|persian', 'fa', 'فارسی');
245 return array('fi|finnish', 'fi', 'Suomi');
247 return array('fr|french', 'fr', 'Français');
249 return array('gl|galician', 'gl', 'Galego');
251 return array('he|hebrew', 'he', 'עברית');
253 return array('hi|hindi', 'hi', 'हिन्दी');
255 return array('hr|croatian', 'hr', 'Hrvatski');
257 return array('hu|hungarian', 'hu', 'Magyar');
259 return array('hy|armenian', 'hy', 'Հայերէն');
261 return array('id|indonesian', 'id', 'Bahasa Indonesia');
263 return array('it|italian', 'it', 'Italiano');
265 return array('ja|japanese', 'ja', '日本語');
267 return array('ko|korean', 'ko', '한국어');
269 return array('ka|georgian', 'ka', 'ქართული');
271 return array('kk|kazakh', 'kk', 'Қазақ');
273 return array('lt|lithuanian', 'lt', 'Lietuvių');
275 return array('lv|latvian', 'lv', 'Latviešu');
277 return array('mk|macedonian', 'mk', 'Macedonian');
279 return array('ml|malayalam', 'ml', 'Malayalam');
281 return array('mn|mongolian', 'mn', 'Монгол');
283 return array('ms|malay', 'ms', 'Bahasa Melayu');
285 return array('nl|dutch', 'nl', 'Nederlands');
287 return array('nb|norwegian', 'nb', 'Norsk');
289 return array('pa|punjabi', 'pa', 'ਪੰਜਾਬੀ');
291 return array('pl|polish', 'pl', 'Polski');
293 return array('pt[-_]br|brazilian portuguese', 'pt-BR', 'Português');
295 return array('pt|portuguese', 'pt', 'Português');
297 return array('ro|romanian', 'ro', 'Română');
299 return array('ru|russian', 'ru', 'Русский');
301 return array('si|sinhala', 'si', 'සිංහල');
303 return array('sk|slovak', 'sk', 'Slovenčina');
305 return array('sl|slovenian', 'sl', 'Slovenščina');
307 return array('sq|albanian', 'sq', 'Shqip');
309 return array('sr[-_]lat|serbian latin', 'sr-lat', 'Srpski');
311 return array('sr|serbian', 'sr', 'Српски');
313 return array('sv|swedish', 'sv', 'Svenska');
315 return array('ta|tamil', 'ta', 'தமிழ்');
317 return array('te|telugu', 'te', 'తెలుగు');
319 return array('th|thai', 'th', 'ภาษาไทย');
321 return array('tk|turkmen', 'tk', 'türkmençe');
323 return array('tr|turkish', 'tr', 'Türkçe');
325 return array('tt|tatarish', 'tt', 'Tatarça');
327 return array('ug|uyghur', 'ug', 'ئۇيغۇرچە');
329 return array('uk|ukrainian', 'uk', 'Українська');
331 return array('ur|urdu', 'ur', 'اُردوُ');
333 return array('uz[-_]lat|uzbek-latin', 'uz-lat', 'O‘zbekcha');
335 return array('uz[-_]cyr|uzbek-cyrillic', 'uz-cyr', 'Ўзбекча');
337 return array('zh[-_](tw|hk)|chinese traditional', 'zh-TW', '中文');
339 // only TW and HK use traditional Chinese while others (CN, SG, MY)
340 // use simplified Chinese
342 'zh(?![-_](tw|hk))([-_][[:alpha:]]{2,3})?|chinese simplified',
347 return array("$lang|$lang", $lang, $lang);
351 * Returns list of languages supported by phpMyAdmin
355 function PMA_langList()
357 /* We can always speak English */
358 $result = array('en' => PMA_langDetails('en'));
360 /* Check for existing directory */
361 if (!is_dir($GLOBALS['lang_path'])) {
365 /* Open the directory */
366 $handle = @opendir
($GLOBALS['lang_path']);
367 /* This can happen if the kit is English-only */
368 if ($handle === false) {
372 /* Process all files */
373 while (false !== ($file = readdir($handle))) {
376 && file_exists($GLOBALS['lang_path'] . '/' . $file . '/LC_MESSAGES/phpmyadmin.mo')
378 $result[$file] = PMA_langDetails($file);
381 /* Close the handle */
388 * @global string path to the translations directory; may be absent if the kit is English-only
390 $GLOBALS['lang_path'] = './locale/';
393 * Load gettext functions.
395 require_once GETTEXT_INC
;
398 * @global string interface language
400 $GLOBALS['lang'] = 'en';
402 * @global boolean whether loading lang from cfg failed
404 $GLOBALS['lang_failed_cfg'] = false;
406 * @global boolean whether loading lang from cookie failed
408 $GLOBALS['lang_failed_cookie'] = false;
410 * @global boolean whether loading lang from user request failed
412 $GLOBALS['lang_failed_request'] = false;
414 * @global string text direction ltr or rtl
416 $GLOBALS['text_dir'] = 'ltr';
419 * @global array supported languages
421 $GLOBALS['available_languages'] = PMA_langList();
423 // Language filtering support
424 if (! empty($GLOBALS['cfg']['FilterLanguages'])) {
426 foreach ($GLOBALS['available_languages'] as $key => $val) {
427 if (preg_match('@' . $GLOBALS['cfg']['FilterLanguages'] . '@', $key)) {
428 $new_lang[$key] = $val;
431 if (count($new_lang) > 0) {
432 $GLOBALS['available_languages'] = $new_lang;
434 unset($key, $val, $new_lang);
438 * @global array MySQL charsets map
440 $GLOBALS['mysql_charset_map'] = array(
445 'gb2312' => 'gb2312',
447 'iso-8859-1' => 'latin1',
448 'iso-8859-2' => 'latin2',
449 'iso-8859-7' => 'greek',
450 'iso-8859-8' => 'hebrew',
451 'iso-8859-8-i' => 'hebrew',
452 'iso-8859-9' => 'latin5',
453 'iso-8859-13' => 'latin7',
454 'iso-8859-15' => 'latin1',
456 'shift_jis' => 'sjis',
457 'tis-620' => 'tis620',
459 'windows-1250' => 'cp1250',
460 'windows-1251' => 'cp1251',
461 'windows-1252' => 'latin1',
462 'windows-1256' => 'cp1256',
463 'windows-1257' => 'cp1257',
470 if (! PMA_langCheck()) {
472 $fall_back_lang = 'en';
474 if (! PMA_langSet($fall_back_lang)) {
476 'phpMyAdmin-ERROR: invalid lang code: '
477 . __FILE__
. '#' . $line . ', check hard coded fall back language.',
481 // and tell the user that his chosen language is invalid
482 PMA_fatalError('Could not load any language, please check your language settings and folder.');
487 _setlocale(LC_MESSAGES
, $GLOBALS['lang']);
488 _bindtextdomain('phpmyadmin', $GLOBALS['lang_path']);
489 _bind_textdomain_codeset('phpmyadmin', 'UTF-8');
490 _textdomain('phpmyadmin');
493 * Messages for phpMyAdmin.
495 * These messages are here for easy transition to Gettext.
496 * You should not add any messages here, use instead gettext directly
497 * in your template/PHP file.
500 if (! function_exists('__')) {
501 PMA_fatalError('Bad invocation!');
504 /* Text direction for language */
505 if (in_array($GLOBALS['lang'], array('ar', 'fa', 'he', 'ur'))) {
506 $GLOBALS['text_dir'] = 'rtl';
508 $GLOBALS['text_dir'] = 'ltr';
512 $GLOBALS['l'] = array();
515 $GLOBALS['l']['a_meta_charset'] = 'UTF-8';
516 $GLOBALS['l']['a_meta_dir'] = $GLOBALS['text_dir'];
517 $GLOBALS['l']['a_meta_language'] = $GLOBALS['lang'];
519 /* TCPDF translations */
520 $GLOBALS['l']['w_page'] = __('Page number:');
523 // now, that we have loaded the language strings we can send the errors
524 if ($GLOBALS['lang_failed_cfg']) {
527 __('Unknown language: %1$s.'),
528 htmlspecialchars($GLOBALS['lang_failed_cfg'])
533 if ($GLOBALS['lang_failed_cookie']) {
536 __('Unknown language: %1$s.'),
537 htmlspecialchars($GLOBALS['lang_failed_cookie'])
542 if ($GLOBALS['lang_failed_request']) {
545 __('Unknown language: %1$s.'),
546 htmlspecialchars($GLOBALS['lang_failed_request'])
553 $line, $fall_back_lang, $GLOBALS['lang_failed_cfg'],
554 $GLOBALS['lang_failed_cookie'], $GLOBALS['lang_failed_request']