diff --git a/CHANGELOG.md b/CHANGELOG.md index fdd63adc..7c163939 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ - MySQL: Display number of found rows in group queries (regression from 5.1.1) - non-MySQL: Parse '--' without trailing space as comment in SQL command (bug SF-842) - CSS: Add logo +- Plugins: Allow formatting translations using Adminer\lang_format() - New plugin: Set up driver, server and database in Adminer Editor ## Adminer 5.1.1 (released 2025-04-02) diff --git a/adminer/include/lang.inc.php b/adminer/include/lang.inc.php index 71b81713..0c537631 100644 --- a/adminer/include/lang.inc.php +++ b/adminer/include/lang.inc.php @@ -1,7 +1,48 @@ $translation +* @param float|string $number +*/ +function lang_format($translation, $number = null): string { + if (is_array($translation)) { + // this is matched by compile.php + $pos = ($number == 1 ? 0 + : (LANG == 'cs' || LANG == 'sk' ? ($number && $number < 5 ? 1 : 2) // different forms for 1, 2-4, other + : (LANG == 'fr' ? (!$number ? 0 : 1) // different forms for 0-1, other + : (LANG == 'pl' ? ($number % 10 > 1 && $number % 10 < 5 && $number / 10 % 10 != 1 ? 1 : 2) // different forms for 1, 2-4 except 12-14, other + : (LANG == 'sl' ? ($number % 100 == 1 ? 0 : ($number % 100 == 2 ? 1 : ($number % 100 == 3 || $number % 100 == 4 ? 2 : 3))) // different forms for 1, 2, 3-4, other + : (LANG == 'lt' ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number % 10 > 1 && $number / 10 % 10 != 1 ? 1 : 2)) // different forms for 1, 12-19, other + : (LANG == 'lv' ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number ? 1 : 2)) // different forms for 1 except 11, other, 0 + : (in_array(LANG, array('bs', 'ru', 'sr', 'uk')) ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number % 10 > 1 && $number % 10 < 5 && $number / 10 % 10 != 1 ? 1 : 2)) // different forms for 1 except 11, 2-4 except 12-14, other + : 1)))))))) // different forms for 1, other + ; // http://www.gnu.org/software/gettext/manual/html_node/Plural-forms.html + $translation = $translation[$pos]; + } + $translation = str_replace("'", '’', $translation); // translations can contain HTML or be used in optionlist (we couldn't escape them here) but they can also be used e.g. in title='' //! escape plaintext translations + $args = func_get_args(); + array_shift($args); + $format = str_replace("%d", "%s", $translation); + if ($format != $translation) { + $args[0] = format_number($number); + } + return vsprintf($format, $args); +} + +// this is matched by compile.php +// not used in a single language version from here /** Get available languages * @return string[] @@ -56,37 +97,6 @@ function langs(): array { ); } -/** Translate string -* @param literal-string $idf -* @param float|string $number -*/ -function lang(string $idf, $number = null): string { - // this is matched by compile.php - $translation = (Lang::$translations[$idf] ?: $idf); - if (is_array($translation)) { - // this is matched by compile.php - $pos = ($number == 1 ? 0 - : (LANG == 'cs' || LANG == 'sk' ? ($number && $number < 5 ? 1 : 2) // different forms for 1, 2-4, other - : (LANG == 'fr' ? (!$number ? 0 : 1) // different forms for 0-1, other - : (LANG == 'pl' ? ($number % 10 > 1 && $number % 10 < 5 && $number / 10 % 10 != 1 ? 1 : 2) // different forms for 1, 2-4 except 12-14, other - : (LANG == 'sl' ? ($number % 100 == 1 ? 0 : ($number % 100 == 2 ? 1 : ($number % 100 == 3 || $number % 100 == 4 ? 2 : 3))) // different forms for 1, 2, 3-4, other - : (LANG == 'lt' ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number % 10 > 1 && $number / 10 % 10 != 1 ? 1 : 2)) // different forms for 1, 12-19, other - : (LANG == 'lv' ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number ? 1 : 2)) // different forms for 1 except 11, other, 0 - : (in_array(LANG, array('bs', 'ru', 'sr', 'uk')) ? ($number % 10 == 1 && $number % 100 != 11 ? 0 : ($number % 10 > 1 && $number % 10 < 5 && $number / 10 % 10 != 1 ? 1 : 2)) // different forms for 1 except 11, 2-4 except 12-14, other - : 1)))))))) // different forms for 1, other - ; // http://www.gnu.org/software/gettext/manual/html_node/Plural-forms.html - $translation = $translation[$pos]; - } - $translation = str_replace("'", '’', $translation); // translations can contain HTML or be used in optionlist (we couldn't escape them here) but they can also be used e.g. in title='' //! escape plaintext translations - $args = func_get_args(); - array_shift($args); - $format = str_replace("%d", "%s", $translation); - if ($format != $translation) { - $args[0] = format_number($number); - } - return vsprintf($format, $args); -} - function switch_lang(): void { echo "