1
0
mirror of https://github.com/searxng/searxng.git synced 2024-11-23 04:27:46 +01:00

[mod] pylint & document searx.locales (settings.yml: remove locales)

- Add ``# lint: pylint`` header to pylint this python file.
- Fix issues reported by pylint.
- Add source code documentation of modul searx.locales

Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
This commit is contained in:
Markus Heiser 2021-08-03 18:17:23 +02:00
parent f30d01ffab
commit 809bf1a105
2 changed files with 32 additions and 4 deletions

View File

@ -0,0 +1,8 @@
.. _searx.locales:
=======
Locales
=======
.. automodule:: searx.locales
:members:

View File

@ -1,3 +1,9 @@
# -*- 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 from typing import List, Set
import os import os
import pathlib import pathlib
@ -10,8 +16,15 @@ LOCALE_NAMES = {
"oc": "Lenga D'òc (Occitan)", "oc": "Lenga D'òc (Occitan)",
"nl_BE": "Vlaams (Dutch, Belgium)", "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] = [] UI_LOCALE_CODES: List[str] = []
"""List of locales e.g. 'fr' or 'pt-BR' (delimiter is '-')"""
RTL_LOCALES: Set[str] = set() 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): def _get_name(locale, language_code):
@ -23,6 +36,11 @@ def _get_name(locale, language_code):
def _get_locale_name(locale, locale_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) native_language, native_territory = _get_name(locale, locale_name)
english_language, english_territory = _get_name(locale, 'en') english_language, english_territory = _get_name(locale, 'en')
if native_territory == english_territory: if native_territory == english_territory:
@ -38,11 +56,13 @@ def _get_locale_name(locale, locale_name):
def initialize_locales(directory): def initialize_locales(directory):
global LOCALE_NAMES, UI_LOCALE_CODES, RTL_LOCALES """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)): for dirname in sorted(os.listdir(directory)):
# Based on https://flask-babel.tkte.ch/_modules/flask_babel.html#Babel.list_translations # Based on https://flask-babel.tkte.ch/_modules/flask_babel.html#Babel.list_translations
locale_dir = os.path.join(directory, dirname, 'LC_MESSAGES') if not os.path.isdir( os.path.join(directory, dirname, 'LC_MESSAGES') ):
if not os.path.isdir(locale_dir):
continue continue
info = LOCALE_NAMES.get(dirname) info = LOCALE_NAMES.get(dirname)
if not info: if not info:
@ -50,7 +70,7 @@ def initialize_locales(directory):
LOCALE_NAMES[dirname] = _get_locale_name(locale, dirname) LOCALE_NAMES[dirname] = _get_locale_name(locale, dirname)
if locale.text_direction == 'rtl': if locale.text_direction == 'rtl':
RTL_LOCALES.add(dirname) RTL_LOCALES.add(dirname)
#
UI_LOCALE_CODES = [l.replace('_', '-') for l in LOCALE_NAMES] UI_LOCALE_CODES = [l.replace('_', '-') for l in LOCALE_NAMES]