fix for a problem with djangojs missing for some languages. Thx Olivier

git-svn-id: http://code.djangoproject.com/svn/django/trunk@1560 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Georg Bauer 2005-12-06 20:30:56 +00:00
parent 631d127bd2
commit 48b67fe4bb
1 changed files with 17 additions and 10 deletions

View File

@ -133,17 +133,23 @@ def javascript_catalog(request, domain='djangojs', packages=None):
locale = to_locale(get_language()) locale = to_locale(get_language())
t = {} t = {}
paths = [] paths = []
# first load all english languages files for defaults
for package in packages: for package in packages:
p = __import__(package, {}, {}, ['']) p = __import__(package, {}, {}, [''])
path = os.path.join(os.path.dirname(p.__file__), 'locale') path = os.path.join(os.path.dirname(p.__file__), 'locale')
paths.append(path) paths.append(path)
#!!! add loading of catalogs from settings.LANGUAGE_CODE and request.LANGUAGE_CODE! catalog = gettext_module.translation(domain, path, ['en'])
try: t.update(catalog._catalog)
catalog = gettext_module.translation(domain, path, [default_locale]) # next load the settings.LANGUAGE_CODE translations if it isn't english
except IOError, e: if default_locale != 'en':
catalog = None for path in paths:
if catalog is not None: try:
t.update(catalog._catalog) catalog = gettext_module.translation(domain, path, [default_locale])
except IOError, e:
catalog = None
if catalog is not None:
t.update(catalog._catalog)
# last load the currently selected language, if it isn't identical to the default.
if locale != default_locale: if locale != default_locale:
for path in paths: for path in paths:
try: try:
@ -154,9 +160,10 @@ def javascript_catalog(request, domain='djangojs', packages=None):
t.update(catalog._catalog) t.update(catalog._catalog)
src = [LibHead] src = [LibHead]
plural = None plural = None
for l in t[''].split('\n'): if t.has_key(''):
if l.startswith('Plural-Forms:'): for l in t[''].split('\n'):
plural = l.split(':',1)[1].strip() if l.startswith('Plural-Forms:'):
plural = l.split(':',1)[1].strip()
if plural is not None: if plural is not None:
# this should actually be a compiled function of a typical plural-form: # this should actually be a compiled function of a typical plural-form:
# Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2; # Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;