diff options
author | Sebastian Spaeth <Sebastian@SSpaeth.de> | 2012-12-02 02:35:04 +0100 |
---|---|---|
committer | Sebastian Spaeth <Sebastian@SSpaeth.de> | 2012-12-02 02:46:50 +0100 |
commit | 826919c97c3fa61f46bef2e2a3708a16f956cfce (patch) | |
tree | 2129269ee9dd36efe33ca5bade1af87fc885b5f5 /mediagoblin/tools/translate.py | |
parent | e4e7fbeeaaf9dc344237453b768d760460290a21 (diff) | |
download | mediagoblin-826919c97c3fa61f46bef2e2a3708a16f956cfce.tar.lz mediagoblin-826919c97c3fa61f46bef2e2a3708a16f956cfce.tar.xz mediagoblin-826919c97c3fa61f46bef2e2a3708a16f956cfce.zip |
en_US is always available
We were using "en" as fallback only when no preferred language matched.
This is obviously bad. Always insert en_US as available locale, so we
can match it with the accept_languages.
Don't set available_locales as mg_global, per discussion with paroneaya,
make it a global var in translate.py
Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
Diffstat (limited to 'mediagoblin/tools/translate.py')
-rw-r--r-- | mediagoblin/tools/translate.py | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/mediagoblin/tools/translate.py b/mediagoblin/tools/translate.py index 2d83316e..8c413056 100644 --- a/mediagoblin/tools/translate.py +++ b/mediagoblin/tools/translate.py @@ -27,18 +27,19 @@ from mediagoblin import mg_globals # Translation tools ################### - +AVAILABLE_LOCALES = None TRANSLATIONS_PATH = pkg_resources.resource_filename( 'mediagoblin', 'i18n') -def get_available_locales(): - """Return a list of locales for which we have translations""" - locales=[] +def set_available_locales(): + """Set available locales for which we have translations""" + global AVAILABLE_LOCALES + locales=['en', 'en_US'] # these are available without translations for locale in localedata.list(): if gettext.find('mediagoblin', TRANSLATIONS_PATH, [locale]): locales.append(locale) - return locales + AVAILABLE_LOCALES = locales def locale_to_lower_upper(locale): @@ -71,6 +72,7 @@ def get_locale_from_request(request): Figure out what target language is most appropriate based on the request """ + global AVAILABLE_LOCALES request_form = request.args or request.form if request_form.has_key('lang'): @@ -87,8 +89,7 @@ def get_locale_from_request(request): # TODO: We need a list of available locales, and match with the list # of accepted locales, and serve the best available locale rather than # the most preferred, or fall back to 'en' immediately. - target_lang = request.accept_languages.best_match( - mg_globals.available_locales) or 'en' + target_lang = request.accept_languages.best_match(AVAILABLE_LOCALES) return locale_to_lower_upper(target_lang) |