diff options
| author | Alexandre Flament <alex@al-f.net> | 2021-08-04 11:05:13 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-08-04 11:05:13 +0200 |
| commit | 4e2ec9b8b30eeb14f0b7e0905bd3e52ecaac831b (patch) | |
| tree | 3f91702b8aa26f4974a0ec8f6a23a52c62f491e8 /searx/locales.py | |
| parent | 34ffd08187d49b2e5de387f63662c18fda800064 (diff) | |
| parent | 0d20e5dfe39b371b550b888db9e6cd7a664bddbb (diff) | |
Merge pull request #247 from dalf/remote_settings_locales
settings.yml: remove locales section.
Diffstat (limited to 'searx/locales.py')
| -rw-r--r-- | searx/locales.py | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/searx/locales.py b/searx/locales.py new file mode 100644 index 000000000..80defceb7 --- /dev/null +++ b/searx/locales.py @@ -0,0 +1,75 @@ +# -*- coding: utf-8 -*- +# SPDX-License-Identifier: AGPL-3.0-or-later +# lint: pylint +"""Initialize :py:obj:`LOCALE_NAMES`, :py:obj:`UI_LOCALE_CODES` and +:py:obj:`RTL_LOCALES`.""" + +from typing import List, Set +import os +import pathlib + +from babel import Locale + +LOCALE_NAMES = { + "oc": "Occitan", + "nl_BE": "Vlaams (Dutch, Belgium)", +} +"""Mapping of locales and their description. Locales e.g. 'fr' or 'pt_BR' +(delimiter is *underline* '_')""" + +UI_LOCALE_CODES: List[str] = [] +"""List of locales e.g. 'fr' or 'pt-BR' (delimiter is '-')""" + +RTL_LOCALES: Set[str] = set() +"""List of *Right-To-Left* locales e.g. 'he' or 'fa_IR' (delimiter is +*underline* '_')""" + + +def _get_name(locale, language_code): + language_name = locale.get_language_name(language_code).capitalize() + if language_name and ('a' <= language_name[0] <= 'z'): + language_name = language_name.capitalize() + terrirtory_name = locale.get_territory_name(language_code) + return language_name, terrirtory_name + + +def _get_locale_name(locale, locale_name): + """Get locale name e.g. 'Français - fr' or 'Português (Brasil) - pt-BR' + + :param locale: instance of :py:class:`Locale` + :param locale_name: name e.g. 'fr' or 'pt_BR' + """ + native_language, native_territory = _get_name(locale, locale_name) + english_language, english_territory = _get_name(locale, 'en') + if native_territory == english_territory: + english_territory = None + if not native_territory and not english_territory: + if native_language == english_language: + return native_language + return native_language + ' (' + english_language + ')' + result = native_language + ', ' + native_territory + ' (' + english_language + if english_territory: + return result + ', ' + english_territory + ')' + return result + ')' + + +def initialize_locales(directory): + """Initialize global names :py:obj:`LOCALE_NAMES`, :py:obj:`UI_LOCALE_CODES` and + :py:obj:`RTL_LOCALES`. + """ + global LOCALE_NAMES, UI_LOCALE_CODES, RTL_LOCALES # pylint: disable=global-statement + for dirname in sorted(os.listdir(directory)): + # Based on https://flask-babel.tkte.ch/_modules/flask_babel.html#Babel.list_translations + if not os.path.isdir( os.path.join(directory, dirname, 'LC_MESSAGES') ): + continue + info = LOCALE_NAMES.get(dirname) + if not info: + locale = Locale.parse(dirname) + LOCALE_NAMES[dirname] = _get_locale_name(locale, dirname) + if locale.text_direction == 'rtl': + RTL_LOCALES.add(dirname) + + UI_LOCALE_CODES = [l.replace('_', '-') for l in LOCALE_NAMES] + + +initialize_locales(pathlib.Path(__file__).parent / 'translations') |