mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #27449 -- Added django.utils.translation.get_supported_language_variant().
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							5033999153
						
					
				
				
					commit
					7905815510
				
			| @@ -205,6 +205,10 @@ def get_language_from_path(path): | |||||||
|     return _trans.get_language_from_path(path) |     return _trans.get_language_from_path(path) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def get_supported_language_variant(lang_code, *, strict=False): | ||||||
|  |     return _trans.get_supported_language_variant(lang_code, strict) | ||||||
|  |  | ||||||
|  |  | ||||||
| def templatize(src, **kwargs): | def templatize(src, **kwargs): | ||||||
|     from .template import templatize |     from .template import templatize | ||||||
|     return templatize(src, **kwargs) |     return templatize(src, **kwargs) | ||||||
|   | |||||||
| @@ -66,3 +66,10 @@ def get_language_from_request(request, check_path=False): | |||||||
|  |  | ||||||
| def get_language_from_path(request): | def get_language_from_path(request): | ||||||
|     return None |     return None | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def get_supported_language_variant(lang_code, strict=False): | ||||||
|  |     if lang_code == settings.LANGUAGE_CODE: | ||||||
|  |         return lang_code | ||||||
|  |     else: | ||||||
|  |         raise LookupError(lang_code) | ||||||
|   | |||||||
| @@ -1092,6 +1092,23 @@ functions without the ``u``. | |||||||
|     for whether its path begins with a language code listed in the |     for whether its path begins with a language code listed in the | ||||||
|     :setting:`LANGUAGES` setting. |     :setting:`LANGUAGES` setting. | ||||||
|  |  | ||||||
|  | .. function:: get_supported_language_variant(lang_code, strict=False) | ||||||
|  |  | ||||||
|  |     .. versionadded:: 2.1 | ||||||
|  |  | ||||||
|  |     Returns ``lang_code`` if it's in the :setting:`LANGUAGES` setting, possibly | ||||||
|  |     selecting a more generic variant. For example, ``'es'`` is returned if | ||||||
|  |     ``lang_code`` is ``'es-ar'`` and ``'es'`` is in :setting:`LANGUAGES` but | ||||||
|  |     ``'es-ar'`` isn't. | ||||||
|  |  | ||||||
|  |     If ``strict`` is ``False`` (the default), a country-specific variant may | ||||||
|  |     be returned when neither the language code nor its generic variant is found. | ||||||
|  |     For example, if only ``'es-co'`` is in :setting:`LANGUAGES`, that's | ||||||
|  |     returned for ``lang_code``\s like ``'es'`` and ``'es-ar'``. Those matches | ||||||
|  |     aren't returned if ``strict=True``. | ||||||
|  |  | ||||||
|  |     Raises :exc:`LookupError` if nothing is found. | ||||||
|  |  | ||||||
| .. function:: to_locale(language) | .. function:: to_locale(language) | ||||||
|  |  | ||||||
|     Turns a language name (en-us) into a locale name (en_US). |     Turns a language name (en-us) into a locale name (en_US). | ||||||
|   | |||||||
| @@ -162,7 +162,8 @@ Generic Views | |||||||
| Internationalization | Internationalization | ||||||
| ~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| * ... | * Added the :meth:`~django.utils.translation.get_supported_language_variant` | ||||||
|  |   function. | ||||||
|  |  | ||||||
| Management Commands | Management Commands | ||||||
| ~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~ | ||||||
|   | |||||||
| @@ -1306,6 +1306,50 @@ class MiscTests(SimpleTestCase): | |||||||
|         r.META = {'HTTP_ACCEPT_LANGUAGE': 'de'} |         r.META = {'HTTP_ACCEPT_LANGUAGE': 'de'} | ||||||
|         self.assertEqual(g(r), 'zh-hans') |         self.assertEqual(g(r), 'zh-hans') | ||||||
|  |  | ||||||
|  |     @override_settings( | ||||||
|  |         USE_I18N=True, | ||||||
|  |         LANGUAGES=[ | ||||||
|  |             ('en', 'English'), | ||||||
|  |             ('de', 'German'), | ||||||
|  |             ('de-at', 'Austrian German'), | ||||||
|  |             ('pt-br', 'Portuguese (Brazil)'), | ||||||
|  |         ], | ||||||
|  |     ) | ||||||
|  |     def test_get_supported_language_variant_real(self): | ||||||
|  |         g = trans_real.get_supported_language_variant | ||||||
|  |         self.assertEqual(g('en'), 'en') | ||||||
|  |         self.assertEqual(g('en-gb'), 'en') | ||||||
|  |         self.assertEqual(g('de'), 'de') | ||||||
|  |         self.assertEqual(g('de-at'), 'de-at') | ||||||
|  |         self.assertEqual(g('de-ch'), 'de') | ||||||
|  |         self.assertEqual(g('pt-br'), 'pt-br') | ||||||
|  |         self.assertEqual(g('pt'), 'pt-br') | ||||||
|  |         self.assertEqual(g('pt-pt'), 'pt-br') | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('pt', strict=True) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('pt-pt', strict=True) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('xyz') | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('xy-zz') | ||||||
|  |  | ||||||
|  |     def test_get_supported_language_variant_null(self): | ||||||
|  |         g = trans_null.get_supported_language_variant | ||||||
|  |         self.assertEqual(g(settings.LANGUAGE_CODE), settings.LANGUAGE_CODE) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('pt') | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('de') | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('de-at') | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('de', strict=True) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('de-at', strict=True) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             g('xyz') | ||||||
|  |  | ||||||
|     @override_settings( |     @override_settings( | ||||||
|         LANGUAGES=[ |         LANGUAGES=[ | ||||||
|             ('en', 'English'), |             ('en', 'English'), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user