[1.8.x] Fixed #24569 -- Made some translation functions accept None value
get_language() can return None when translations are deactivated.
Thanks Nicola Peduzzi for the reporti and Tim Graham for the review.
Backport of 7a0d9b5cda
from master.
This commit is contained in:
parent
7821f856a6
commit
3a76276212
|
@ -260,8 +260,12 @@ def get_language_bidi():
|
||||||
* False = left-to-right layout
|
* False = left-to-right layout
|
||||||
* True = right-to-left layout
|
* True = right-to-left layout
|
||||||
"""
|
"""
|
||||||
base_lang = get_language().split('-')[0]
|
lang = get_language()
|
||||||
return base_lang in settings.LANGUAGES_BIDI
|
if lang is None:
|
||||||
|
return False
|
||||||
|
else:
|
||||||
|
base_lang = get_language().split('-')[0]
|
||||||
|
return base_lang in settings.LANGUAGES_BIDI
|
||||||
|
|
||||||
|
|
||||||
def catalog():
|
def catalog():
|
||||||
|
@ -406,7 +410,7 @@ def check_for_language(lang_code):
|
||||||
<https://www.djangoproject.com/weblog/2007/oct/26/security-fix/>.
|
<https://www.djangoproject.com/weblog/2007/oct/26/security-fix/>.
|
||||||
"""
|
"""
|
||||||
# First, a quick check to make sure lang_code is well-formed (#21458)
|
# First, a quick check to make sure lang_code is well-formed (#21458)
|
||||||
if not language_code_re.search(lang_code):
|
if lang_code is None or not language_code_re.search(lang_code):
|
||||||
return False
|
return False
|
||||||
for path in all_locale_paths():
|
for path in all_locale_paths():
|
||||||
if gettext_module.find('django', path, [to_locale(lang_code)]) is not None:
|
if gettext_module.find('django', path, [to_locale(lang_code)]) is not None:
|
||||||
|
|
|
@ -14,3 +14,6 @@ Bugfixes
|
||||||
|
|
||||||
* Restored proper parsing of the :djadmin:`testserver` command's positional
|
* Restored proper parsing of the :djadmin:`testserver` command's positional
|
||||||
arguments (fixture names) (:ticket:`24571`).
|
arguments (fixture names) (:ticket:`24571`).
|
||||||
|
|
||||||
|
* Prevented ``TypeError`` in translation functions ``check_for_language()`` and
|
||||||
|
``get_language_bidi()`` when translations are deactivated (:ticket:`24569`).
|
||||||
|
|
|
@ -26,10 +26,10 @@ from django.utils.safestring import SafeBytes, SafeString, SafeText, mark_safe
|
||||||
from django.utils.six import PY3
|
from django.utils.six import PY3
|
||||||
from django.utils.translation import (
|
from django.utils.translation import (
|
||||||
LANGUAGE_SESSION_KEY, activate, check_for_language, deactivate,
|
LANGUAGE_SESSION_KEY, activate, check_for_language, deactivate,
|
||||||
get_language, get_language_from_request, get_language_info, gettext,
|
get_language, get_language_bidi, get_language_from_request,
|
||||||
gettext_lazy, ngettext_lazy, npgettext, npgettext_lazy, pgettext,
|
get_language_info, gettext, gettext_lazy, ngettext_lazy, npgettext,
|
||||||
pgettext_lazy, string_concat, to_locale, trans_real, ugettext,
|
npgettext_lazy, pgettext, pgettext_lazy, string_concat, to_locale,
|
||||||
ugettext_lazy, ungettext, ungettext_lazy,
|
trans_real, ugettext, ugettext_lazy, ungettext, ungettext_lazy,
|
||||||
)
|
)
|
||||||
|
|
||||||
from .forms import CompanyForm, I18nForm, SelectDateForm, SelectDateWidget
|
from .forms import CompanyForm, I18nForm, SelectDateForm, SelectDateWidget
|
||||||
|
@ -401,6 +401,11 @@ class TranslationTests(TestCase):
|
||||||
self.assertEqual(trans_real.to_language('en_US'), 'en-us')
|
self.assertEqual(trans_real.to_language('en_US'), 'en-us')
|
||||||
self.assertEqual(trans_real.to_language('sr_Lat'), 'sr-lat')
|
self.assertEqual(trans_real.to_language('sr_Lat'), 'sr-lat')
|
||||||
|
|
||||||
|
def test_language_bidi(self):
|
||||||
|
self.assertEqual(get_language_bidi(), False)
|
||||||
|
with translation.override(None):
|
||||||
|
self.assertEqual(get_language_bidi(), False)
|
||||||
|
|
||||||
@override_settings(LOCALE_PATHS=(os.path.join(here, 'other', 'locale'),))
|
@override_settings(LOCALE_PATHS=(os.path.join(here, 'other', 'locale'),))
|
||||||
def test_bad_placeholder_1(self):
|
def test_bad_placeholder_1(self):
|
||||||
"""
|
"""
|
||||||
|
@ -1446,6 +1451,7 @@ class CountrySpecificLanguageTests(TestCase):
|
||||||
self.assertTrue(check_for_language('en-US'))
|
self.assertTrue(check_for_language('en-US'))
|
||||||
self.assertFalse(check_for_language('en-ü'))
|
self.assertFalse(check_for_language('en-ü'))
|
||||||
self.assertFalse(check_for_language('en\x00'))
|
self.assertFalse(check_for_language('en\x00'))
|
||||||
|
self.assertFalse(check_for_language(None))
|
||||||
|
|
||||||
def test_get_language_from_request(self):
|
def test_get_language_from_request(self):
|
||||||
# issue 19919
|
# issue 19919
|
||||||
|
|
Loading…
Reference in New Issue