mirror of
https://github.com/Hopiu/linkchecker.git
synced 2026-04-03 06:30:23 +00:00
164 lines
4.9 KiB
Python
164 lines
4.9 KiB
Python
# Copyright (C) 2000-2014 Bastian Kleineidam
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
"""
|
|
Application internationalization support.
|
|
"""
|
|
|
|
# i18n support
|
|
import os
|
|
import locale
|
|
import gettext
|
|
import sys
|
|
import codecs
|
|
|
|
# more supported languages are added in init()
|
|
supported_languages = set(['en'])
|
|
default_language = default_encoding = None
|
|
default_directory = None
|
|
default_domain = None
|
|
|
|
|
|
def install_builtin(translator, do_unicode):
|
|
"""Install _() and _n() gettext methods into default namespace."""
|
|
import builtins
|
|
|
|
builtins.__dict__['_'] = translator.gettext
|
|
# also install ngettext
|
|
builtins.__dict__['_n'] = translator.ngettext
|
|
|
|
|
|
class Translator(gettext.GNUTranslations):
|
|
"""A translation class always installing its gettext methods into the
|
|
default namespace."""
|
|
|
|
def install(self, do_unicode):
|
|
"""Install gettext methods into the default namespace."""
|
|
install_builtin(self, do_unicode)
|
|
|
|
|
|
class NullTranslator(gettext.NullTranslations):
|
|
"""A dummy translation class always installing its gettext methods into
|
|
the default namespace."""
|
|
|
|
def install(self, do_unicode):
|
|
"""Install gettext methods into the default namespace."""
|
|
install_builtin(self, do_unicode)
|
|
|
|
|
|
def init(domain, directory, loc=None):
|
|
"""Initialize this gettext i18n module. Searches for supported languages
|
|
and installs the gettext translator class."""
|
|
global default_language, default_encoding, default_domain, default_directory
|
|
default_directory = directory
|
|
default_domain = domain
|
|
if os.path.isdir(directory):
|
|
# get supported languages
|
|
for lang in os.listdir(directory):
|
|
path = os.path.join(directory, lang, 'LC_MESSAGES')
|
|
mo_file = os.path.join(path, '%s.mo' % domain)
|
|
if os.path.exists(mo_file):
|
|
supported_languages.add(lang)
|
|
if loc is None:
|
|
loc, encoding = get_locale()
|
|
else:
|
|
encoding = get_locale()[1]
|
|
if loc in supported_languages:
|
|
default_language = loc
|
|
else:
|
|
default_language = "en"
|
|
# Even if the default language is not supported, the encoding should
|
|
# be installed. Otherwise the Python installation is borked.
|
|
default_encoding = encoding
|
|
install_language(default_language)
|
|
|
|
|
|
def install_language(language):
|
|
"""Install translation service routines into default namespace."""
|
|
translator = get_translator(
|
|
default_domain, default_directory, languages=[get_lang(language)], fallback=True
|
|
)
|
|
do_unicode = True
|
|
translator.install(do_unicode)
|
|
|
|
|
|
def get_translator(
|
|
domain,
|
|
directory,
|
|
languages=None,
|
|
translatorklass=Translator,
|
|
fallback=False,
|
|
fallbackklass=NullTranslator,
|
|
):
|
|
"""Search the appropriate GNUTranslations class."""
|
|
translator = gettext.translation(
|
|
domain,
|
|
localedir=directory,
|
|
languages=languages,
|
|
class_=translatorklass,
|
|
fallback=fallback,
|
|
)
|
|
if not isinstance(translator, gettext.GNUTranslations) and fallbackklass:
|
|
translator = fallbackklass()
|
|
return translator
|
|
|
|
|
|
def get_lang(lang):
|
|
"""Return lang if it is supported, or the default language."""
|
|
if lang in supported_languages:
|
|
return lang
|
|
return default_language
|
|
|
|
|
|
def get_locale():
|
|
"""Search the default platform locale and norm it.
|
|
@returns (locale, encoding)
|
|
@rtype (string, string)"""
|
|
try:
|
|
loc, encoding = locale.getdefaultlocale()
|
|
except ValueError:
|
|
# locale configuration is broken - ignore that
|
|
loc, encoding = None, None
|
|
if loc is None:
|
|
loc = "C"
|
|
else:
|
|
loc = norm_locale(loc)
|
|
if encoding is None:
|
|
encoding = "ascii"
|
|
return (loc, encoding)
|
|
|
|
|
|
def norm_locale(loc):
|
|
"""Normalize a locale."""
|
|
loc = locale.normalize(loc)
|
|
# split up the locale into its base components
|
|
pos = loc.find('@')
|
|
if pos >= 0:
|
|
loc = loc[:pos]
|
|
pos = loc.find('.')
|
|
if pos >= 0:
|
|
loc = loc[:pos]
|
|
pos = loc.find('_')
|
|
if pos >= 0:
|
|
loc = loc[:pos]
|
|
return loc
|
|
|
|
|
|
def get_encoded_writer(out=sys.stdout, encoding=None, errors='replace'):
|
|
"""Get wrapped output writer with given encoding and error handling."""
|
|
if encoding is None:
|
|
encoding = default_encoding
|
|
Writer = codecs.getwriter(encoding)
|
|
return Writer(out.buffer, errors)
|