GrampsLocale: Code cleanup
And make sure that setting lang on the GrampsLocale constructor overrides the languages from the first instance. svn: r21646
This commit is contained in:
parent
76ef85b43f
commit
29292a404a
@ -98,12 +98,12 @@ class GrampsLocale(object):
|
||||
|
||||
return super(GrampsLocale, cls).__new__(cls)
|
||||
|
||||
def __init_from_environment(self, lang=None, language=None):
|
||||
if not lang:
|
||||
def __init_from_environment(self):
|
||||
if not (hasattr(self, 'lang') and self.lang):
|
||||
lang = ' '
|
||||
try:
|
||||
if 'LANG' in os.environ:
|
||||
lang = os.environ["LANG"]
|
||||
except KeyError:
|
||||
else:
|
||||
lang = locale.getlocale()[0]
|
||||
if not lang:
|
||||
try:
|
||||
@ -113,29 +113,36 @@ class GrampsLocale(object):
|
||||
lang = 'C.UTF-8'
|
||||
self.lang = lang
|
||||
|
||||
if not language or len(language) == 0:
|
||||
if not self.language:
|
||||
if "LANGUAGE" in os.environ:
|
||||
avail = self.get_available_translations()
|
||||
language = [l for l in os.environ["LANGUAGE"].split(":")
|
||||
if l[:5] in avail or l[:2] in avail]
|
||||
language = [x for x in [self.check_available_translations(l)
|
||||
for l in os.environ["LANGUAGE"].split(":")]
|
||||
if x]
|
||||
|
||||
self.language = language
|
||||
elif not lang == "C.UTF-8":
|
||||
elif 'LC_MESSAGES' in os.environ:
|
||||
lang = self.check_available_translations(os.environ['LC_MESSAGES'])
|
||||
if lang:
|
||||
self.language = [lang]
|
||||
elif not self.lang == "C.UTF-8":
|
||||
l = self.check_available_translations(lang)
|
||||
if l:
|
||||
self.language = [l]
|
||||
else:
|
||||
self.language = ["en"]
|
||||
|
||||
if "LC_MONETARY" not in os.environ:
|
||||
self.currency = lang
|
||||
self.currency = self.lang
|
||||
else:
|
||||
self.currency = os.environ["LC_MONETARY"]
|
||||
|
||||
if "LC_TIME" not in os.environ:
|
||||
self.calendar = lang
|
||||
self.calendar = self.lang
|
||||
else:
|
||||
self.calendar = os.environ["LC_TIME"]
|
||||
|
||||
if "LC_COLLATE" not in os.environ:
|
||||
self.collation = lang
|
||||
self.collation = self.lang
|
||||
else:
|
||||
self.collation = os.environ["LC_COLLATE"]
|
||||
|
||||
@ -155,9 +162,7 @@ class GrampsLocale(object):
|
||||
except WindowsError:
|
||||
LOG.warning("Localization library libintl not on %PATH%, localization will be incomplete")
|
||||
|
||||
|
||||
def __init_first_instance(self, localedir, lang=None,
|
||||
domain=None, language=None):
|
||||
def __init_first_instance(self, localedir):
|
||||
global _hdlr
|
||||
_hdlr = logging.StreamHandler()
|
||||
_hdlr.setFormatter(logging.Formatter(fmt="%(name)s.%(levelname)s: %(message)s"))
|
||||
@ -169,36 +174,23 @@ class GrampsLocale(object):
|
||||
except locale.Error:
|
||||
pass
|
||||
|
||||
if localedir and os.path.exists(localedir):
|
||||
self.localedir = localedir
|
||||
else:
|
||||
if not lang:
|
||||
lang = os.environ.get('LANG', 'en')
|
||||
if lang and lang[:2] == 'en':
|
||||
pass # No need to display warning, we're in English
|
||||
else:
|
||||
LOG.warning('Locale dir does not exist at %s', localedir)
|
||||
LOG.warning('Running python setup.py install --prefix=YourPrefixDir might fix the problem')
|
||||
|
||||
if not self.localedir:
|
||||
#No localization files, no point in continuing
|
||||
return
|
||||
if domain:
|
||||
self.localedomain = domain
|
||||
else:
|
||||
self.localedomain = 'gramps'
|
||||
|
||||
if not language or not isinstance(language, list):
|
||||
language = []
|
||||
else:
|
||||
language = [l for l in languages
|
||||
if l in self.get_available_translations()]
|
||||
|
||||
if not (hasattr(self, 'lang') and self.lang
|
||||
and hasattr(self, 'language') and self.language):
|
||||
if mac():
|
||||
from . import maclocale
|
||||
maclocale.mac_setup_localization(self, lang, language)
|
||||
maclocale.mac_setup_localization(self)
|
||||
else:
|
||||
self.__init_from_environment(lang, language)
|
||||
self.__init_from_environment()
|
||||
else:
|
||||
self.currency = self.calendar = self.collation = self.lang
|
||||
|
||||
if not self.lang:
|
||||
self.lang = 'en_US.UTF-8'
|
||||
if not self.language:
|
||||
self.language.append('en')
|
||||
if not self.have_localedir and not self.lang.startswith('en'):
|
||||
LOG.warning("No translations for %s were found, setting localization to U.S. English", self.localedomain)
|
||||
|
||||
#A variety of useful functions use the current locale for
|
||||
#formatting. Pending global replacement of those functions with ICU
|
||||
#equivalents, we need to use setlocale to our chosen default. This
|
||||
@ -238,7 +230,6 @@ class GrampsLocale(object):
|
||||
else:
|
||||
self._win_bindtextdomain(self.localedomain, self.localedir)
|
||||
|
||||
self.initialized = True
|
||||
|
||||
def __init__(self, localedir=None, lang=None, domain=None, languages=None):
|
||||
"""
|
||||
@ -247,36 +238,49 @@ class GrampsLocale(object):
|
||||
otherwise if called without arguments.
|
||||
"""
|
||||
global _hdlr
|
||||
if self == self._GrampsLocale__first_instance:
|
||||
if not self.initialized:
|
||||
self._GrampsLocale__init_first_instance(localedir, lang,
|
||||
domain, languages)
|
||||
else:
|
||||
|
||||
if hasattr(self, 'initialized') and self.initialized:
|
||||
return
|
||||
|
||||
else:
|
||||
_first = self._GrampsLocale__first_instance
|
||||
self.have_localedir = True
|
||||
|
||||
if domain:
|
||||
self.localedomain = domain
|
||||
elif hasattr(_first, 'localedomain'):
|
||||
self.localedomain = _first.localedomain
|
||||
else:
|
||||
self.localedomain = self._GrampsLocale__first_instance.localedomain
|
||||
if localedir:
|
||||
self.localedomain = "gramps"
|
||||
if localedir and os.path.exists(localedir):
|
||||
self.localedir = localedir
|
||||
elif hasattr(_first, 'localedir'):
|
||||
self.localedir = _first.localedir
|
||||
else:
|
||||
self.localedir = self._GrampsLocale__first_instance.localedir
|
||||
|
||||
self.language = []
|
||||
if languages and len(languages) > 0:
|
||||
self.language = [l for l in languages
|
||||
if l in self.get_available_translations()]
|
||||
if len(self.language) == 0:
|
||||
self.language = self._GrampsLocale__first_instance.language
|
||||
self.have_localedir = False
|
||||
|
||||
if lang:
|
||||
self.lang = lang
|
||||
else:
|
||||
self.lang = self._GrampsLocale__first_instance.lang
|
||||
elif hasattr(_first, 'lang'):
|
||||
self.lang = _first.lang
|
||||
|
||||
self.language = []
|
||||
if languages:
|
||||
self.language = [x for x in [self.check_available_translations(l)
|
||||
for l in languages]
|
||||
if x]
|
||||
elif hasattr(self, 'lang') and self.lang:
|
||||
trans = self.check_available_translations(lang)
|
||||
if trans:
|
||||
self.language.append(trans)
|
||||
|
||||
if not self.language and hasattr(_first, 'language'):
|
||||
self.language = _first.language
|
||||
|
||||
if self == _first:
|
||||
self._GrampsLocale__init_first_instance(localedir)
|
||||
else:
|
||||
self.currency = self.calendar = self.collation = self.lang
|
||||
|
||||
self.collation = self.currency = self.calendar = self.lang
|
||||
|
||||
self.icu_locales = {}
|
||||
self.collator = None
|
||||
@ -294,10 +298,11 @@ class GrampsLocale(object):
|
||||
|
||||
self.translation = self._get_translation(self.localedomain,
|
||||
self.localedir, self.language)
|
||||
self._set_dictionaries()
|
||||
if _hdlr:
|
||||
LOG.removeHandler(_hdlr)
|
||||
|
||||
self.initialized = True
|
||||
|
||||
def _get_translation(self, domain = None,
|
||||
localedir = None,
|
||||
languages=None):
|
||||
@ -390,6 +395,9 @@ class GrampsLocale(object):
|
||||
code_parts = lang_code.rsplit("_")
|
||||
|
||||
lang = code_parts[0]
|
||||
if not hasattr(self, 'lang_map'):
|
||||
self._set_dictionaries()
|
||||
|
||||
if lang in self.lang_map:
|
||||
lang = self.lang_map[lang]
|
||||
|
||||
@ -487,7 +495,7 @@ class GrampsLocale(object):
|
||||
gramps_translator.add_fallback(addon_translator)
|
||||
return gramps_translator # with a language fallback
|
||||
|
||||
def get_available_translations(self):
|
||||
def get_available_translations(self, localedir = None, localedomain = None):
|
||||
"""
|
||||
Get a list of available translations.
|
||||
|
||||
@ -497,13 +505,19 @@ class GrampsLocale(object):
|
||||
"""
|
||||
languages = ["en"]
|
||||
|
||||
if self.localedir is None:
|
||||
if not localedir and hasattr(self, 'localedir'):
|
||||
localedir = self.localedir
|
||||
|
||||
if localedir is None:
|
||||
return languages
|
||||
|
||||
if not localedomain and hasattr(self, 'localedomain'):
|
||||
localedomain = self.localedomain
|
||||
|
||||
for langdir in os.listdir(self.localedir):
|
||||
mofilename = os.path.join(self.localedir, langdir,
|
||||
mofilename = os.path.join(localedir, langdir,
|
||||
"LC_MESSAGES",
|
||||
"%s.mo" % self.localedomain )
|
||||
"%s.mo" % localedomain )
|
||||
if os.path.exists(mofilename):
|
||||
languages.append(langdir)
|
||||
|
||||
@ -511,6 +525,23 @@ class GrampsLocale(object):
|
||||
|
||||
return languages
|
||||
|
||||
def check_available_translations(self, locale):
|
||||
"""
|
||||
Test a locale for having a translation available
|
||||
locale -- string with standard language code, locale code, or name
|
||||
"""
|
||||
if not self.have_localedir:
|
||||
return None
|
||||
if not hasattr(self, 'languages'):
|
||||
self.languages = self.get_available_translations()
|
||||
|
||||
if locale[:2] in self.languages:
|
||||
return locale[:2]
|
||||
if locale[:5] in self.languages:
|
||||
return locale[:5]
|
||||
|
||||
return None
|
||||
|
||||
def get_language_dict(self):
|
||||
'''
|
||||
return a dictionary of language names : codes for use by language
|
||||
|
@ -73,7 +73,7 @@ locale, leaving $LANGUAGE unset (which is the same as setting it to
|
||||
|
||||
import sys, os, subprocess
|
||||
|
||||
def mac_setup_localization(glocale, lang, language):
|
||||
def mac_setup_localization(glocale):
|
||||
"""
|
||||
Set up the localization parameters from OSX's "defaults" system,
|
||||
permitting environment variables to override the settings.
|
||||
@ -81,10 +81,6 @@ def mac_setup_localization(glocale, lang, language):
|
||||
defaults = "/usr/bin/defaults"
|
||||
find = "/usr/bin/find"
|
||||
locale_dir = "/usr/share/locale"
|
||||
if glocale:
|
||||
available = glocale.get_available_translations()
|
||||
else:
|
||||
available = ['en']
|
||||
|
||||
def _mac_get_gramps_defaults(pref):
|
||||
try:
|
||||
@ -121,8 +117,8 @@ def mac_setup_localization(glocale, lang, language):
|
||||
lang = "cn_TW"
|
||||
if lang == "cn_Hans": #Simplified; Gettext uses cn_CN
|
||||
lang = "cn_CN"
|
||||
|
||||
if lang in available or lang[:2] in available:
|
||||
lang = glocale.check_available_translations(lang)
|
||||
if lang:
|
||||
usable.append(lang)
|
||||
|
||||
return usable
|
||||
@ -203,13 +199,12 @@ def mac_setup_localization(glocale, lang, language):
|
||||
# The action starts here
|
||||
|
||||
(loc, currency, calendar) = mac_get_locale()
|
||||
translations = mac_language_list()
|
||||
if "LC_COLLATE" in os.environ:
|
||||
collation = os.environ["LC_COLLATE"]
|
||||
else:
|
||||
collation = mac_get_collation()
|
||||
|
||||
if not lang:
|
||||
if not (hasattr(glocale, 'lang') and glocale.lang):
|
||||
if "LANG" in os.environ:
|
||||
lang = os.environ["LANG"]
|
||||
else:
|
||||
@ -222,21 +217,32 @@ def mac_setup_localization(glocale, lang, language):
|
||||
|
||||
glocale.lang = lang
|
||||
|
||||
if not language or len(language) == 0:
|
||||
if not glocale.language:
|
||||
if "LANGUAGE" in os.environ:
|
||||
language = [l[:5] for l in os.environ["LANGUAGE"].split(":")
|
||||
if l[:5] in available or l[:2] in available]
|
||||
elif "LANG" in os.environ and not lang.startswith("en_US"):
|
||||
language = [lang[:5]]
|
||||
language = [x for x in [glocale.check_available_translations(l)
|
||||
for l in os.environ["LANGUAGE"].split(":")]
|
||||
if x]
|
||||
elif ("LANG" in os.environ
|
||||
and not os.environ['LANG'].startswith("en_US")):
|
||||
lang = glocale.check_available_translations(os.environ['LANG'])
|
||||
if lang:
|
||||
language = [lang]
|
||||
|
||||
else:
|
||||
translations = mac_language_list()
|
||||
if len(translations) > 0:
|
||||
language = translations
|
||||
elif (len(loc) > 0 and loc in available
|
||||
and not loc.startswith("en")):
|
||||
language = [loc]
|
||||
lang = glocale.check_available_translations(loc)
|
||||
if lang:
|
||||
language = [lang]
|
||||
elif (collation and len(collation) > 0 and collation in available
|
||||
and not collation.startswith("en")):
|
||||
language = [collation]
|
||||
lang = glocale.check_available_translations(collation)
|
||||
if lang:
|
||||
language = [lang]
|
||||
|
||||
glocale.language = language
|
||||
|
||||
if (currency and "LC_MONETARY" not in os.environ
|
||||
@ -246,7 +252,7 @@ def mac_setup_localization(glocale, lang, language):
|
||||
elif "LC_MONETARY" in os.environ:
|
||||
glocale.currency = os.environ[LC_MONETARY]
|
||||
else:
|
||||
glocale.currency = lang
|
||||
glocale.currency = glocale.lang
|
||||
|
||||
if (calendar and "LC_TIME" not in os.environ
|
||||
and "LANG" not in os.environ):
|
||||
@ -255,7 +261,7 @@ def mac_setup_localization(glocale, lang, language):
|
||||
elif "LC_TIME" in os.environ:
|
||||
glocale.calendar = os.environ["LC_TIME"]
|
||||
else:
|
||||
glocale.calendar = lang
|
||||
glocale.calendar = glocale.lang
|
||||
|
||||
if (collation and "LC_COLLATION" not in os.environ
|
||||
and "LANG" not in os.environ):
|
||||
@ -264,6 +270,6 @@ def mac_setup_localization(glocale, lang, language):
|
||||
elif "LC_COLLATION" in os.environ:
|
||||
glocale.collation = os.environ["LC_COLLATION"]
|
||||
else:
|
||||
glocale.collation = lang
|
||||
glocale.collation = glocale.lang
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user