Refactor i18n
- Make _() available, so other modules can import it from i18n, we need this because mypy cant handle _() in the builtins namespace
This commit is contained in:
parent
2649b3d01e
commit
21672fadee
|
@ -29,45 +29,6 @@ direction_mark = '\u200E'
|
||||||
_translations = None
|
_translations = None
|
||||||
|
|
||||||
|
|
||||||
def initialize():
|
|
||||||
global _translations
|
|
||||||
try:
|
|
||||||
locale.setlocale(locale.LC_ALL, '')
|
|
||||||
except locale.Error as error:
|
|
||||||
print(error)
|
|
||||||
|
|
||||||
initialize_lang()
|
|
||||||
set_i18n_env()
|
|
||||||
|
|
||||||
localedir = get_locale_dir()
|
|
||||||
if hasattr(locale, 'bindtextdomain'):
|
|
||||||
locale.bindtextdomain(DOMAIN, localedir)
|
|
||||||
|
|
||||||
gettext.install(DOMAIN, localedir)
|
|
||||||
if gettext._translations:
|
|
||||||
_translations = list(gettext._translations.values())[0]
|
|
||||||
else:
|
|
||||||
_translations = gettext.NullTranslations()
|
|
||||||
|
|
||||||
|
|
||||||
def set_i18n_env():
|
|
||||||
if os.name == 'nt':
|
|
||||||
os.environ['LANG'] = LANG
|
|
||||||
|
|
||||||
|
|
||||||
def initialize_lang():
|
|
||||||
global LANG
|
|
||||||
try:
|
|
||||||
# en_US, fr_FR, el_GR etc..
|
|
||||||
default = locale.getdefaultlocale()[0]
|
|
||||||
if default is None:
|
|
||||||
# LC_ALL=C
|
|
||||||
return
|
|
||||||
LANG = default[:2]
|
|
||||||
except (ValueError, locale.Error):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def get_locale_dir():
|
def get_locale_dir():
|
||||||
if os.name == 'nt':
|
if os.name == 'nt':
|
||||||
return None
|
return None
|
||||||
|
@ -75,9 +36,9 @@ def get_locale_dir():
|
||||||
path = gettext.find(DOMAIN)
|
path = gettext.find(DOMAIN)
|
||||||
if path:
|
if path:
|
||||||
# extract localedir from localedir/language/LC_MESSAGES/domain.mo
|
# extract localedir from localedir/language/LC_MESSAGES/domain.mo
|
||||||
path, tail = os.path.split(path)
|
path = os.path.split(path)[1]
|
||||||
path, tail = os.path.split(path)
|
path = os.path.split(path)[1]
|
||||||
localedir, tail = os.path.split(path)
|
localedir = os.path.split(path)[1]
|
||||||
elif os.path.exists('/app/share/run-as-flatpak'):
|
elif os.path.exists('/app/share/run-as-flatpak'):
|
||||||
# Check if we run as flatpak
|
# Check if we run as flatpak
|
||||||
return '/app/share/locale'
|
return '/app/share/locale'
|
||||||
|
@ -110,7 +71,7 @@ def paragraph_direction_mark(text):
|
||||||
bidi = unicodedata.bidirectional(char)
|
bidi = unicodedata.bidirectional(char)
|
||||||
if bidi == 'L':
|
if bidi == 'L':
|
||||||
return '\u200E'
|
return '\u200E'
|
||||||
elif bidi == 'AL' or bidi == 'R':
|
if bidi in ('AL', 'R'):
|
||||||
return '\u200F'
|
return '\u200F'
|
||||||
|
|
||||||
return '\u200E'
|
return '\u200E'
|
||||||
|
@ -133,14 +94,15 @@ def Q_(text):
|
||||||
"""
|
"""
|
||||||
text = _(text)
|
text = _(text)
|
||||||
if text.startswith('?'):
|
if text.startswith('?'):
|
||||||
qualifier, text = text.split(':', 1)
|
text = text.split(':', 1)[1]
|
||||||
return text
|
return text
|
||||||
|
|
||||||
|
|
||||||
def ngettext(s_sing, s_plural, n, replace_sing=None, replace_plural=None):
|
def ngettext(s_sing, s_plural, n, replace_sing=None, replace_plural=None):
|
||||||
"""
|
"""
|
||||||
Use as:
|
Use as:
|
||||||
i18n.ngettext('leave room %s', 'leave rooms %s', len(rooms), 'a', 'a, b, c')
|
i18n.ngettext(
|
||||||
|
'leave room %s', 'leave rooms %s', len(rooms), 'a', 'a, b, c')
|
||||||
|
|
||||||
In other words this is a hack to ngettext() to support %s %d etc..
|
In other words this is a hack to ngettext() to support %s %d etc..
|
||||||
"""
|
"""
|
||||||
|
@ -152,4 +114,31 @@ def ngettext(s_sing, s_plural, n, replace_sing=None, replace_plural=None):
|
||||||
return text
|
return text
|
||||||
|
|
||||||
|
|
||||||
initialize()
|
try:
|
||||||
|
locale.setlocale(locale.LC_ALL, '')
|
||||||
|
except locale.Error as error:
|
||||||
|
print(error)
|
||||||
|
|
||||||
|
try:
|
||||||
|
# en_US, fr_FR, el_GR etc..
|
||||||
|
default = locale.getdefaultlocale()[0]
|
||||||
|
if default is not None:
|
||||||
|
LANG = default[:2]
|
||||||
|
except (ValueError, locale.Error):
|
||||||
|
pass
|
||||||
|
|
||||||
|
if os.name == 'nt':
|
||||||
|
os.environ['LANG'] = LANG
|
||||||
|
|
||||||
|
_localedir = get_locale_dir()
|
||||||
|
if hasattr(locale, 'bindtextdomain'):
|
||||||
|
locale.bindtextdomain(DOMAIN, _localedir)
|
||||||
|
gettext.textdomain(DOMAIN)
|
||||||
|
|
||||||
|
gettext.install(DOMAIN, _localedir)
|
||||||
|
_ = gettext.translation(DOMAIN, _localedir).gettext
|
||||||
|
|
||||||
|
if gettext._translations:
|
||||||
|
_translations = list(gettext._translations.values())[0]
|
||||||
|
else:
|
||||||
|
_translations = gettext.NullTranslations()
|
||||||
|
|
Loading…
Reference in New Issue