[py3] Ported django.utils.translation.
This commit is contained in:
parent
17da0aa893
commit
9e8df02d68
|
@ -9,7 +9,9 @@ import gettext as gettext_module
|
||||||
from threading import local
|
from threading import local
|
||||||
|
|
||||||
from django.utils.importlib import import_module
|
from django.utils.importlib import import_module
|
||||||
|
from django.utils.encoding import smart_str, smart_text
|
||||||
from django.utils.safestring import mark_safe, SafeData
|
from django.utils.safestring import mark_safe, SafeData
|
||||||
|
from django.utils import six
|
||||||
from django.utils.six import StringIO
|
from django.utils.six import StringIO
|
||||||
|
|
||||||
|
|
||||||
|
@ -259,12 +261,14 @@ def do_translate(message, translation_function):
|
||||||
def gettext(message):
|
def gettext(message):
|
||||||
return do_translate(message, 'gettext')
|
return do_translate(message, 'gettext')
|
||||||
|
|
||||||
|
if six.PY3:
|
||||||
|
ugettext = gettext
|
||||||
|
else:
|
||||||
def ugettext(message):
|
def ugettext(message):
|
||||||
return do_translate(message, 'ugettext')
|
return do_translate(message, 'ugettext')
|
||||||
|
|
||||||
def pgettext(context, message):
|
def pgettext(context, message):
|
||||||
result = do_translate(
|
result = ugettext("%s%s%s" % (context, CONTEXT_SEPARATOR, message))
|
||||||
"%s%s%s" % (context, CONTEXT_SEPARATOR, message), 'ugettext')
|
|
||||||
if CONTEXT_SEPARATOR in result:
|
if CONTEXT_SEPARATOR in result:
|
||||||
# Translation not found
|
# Translation not found
|
||||||
result = message
|
result = message
|
||||||
|
@ -297,6 +301,9 @@ def ngettext(singular, plural, number):
|
||||||
"""
|
"""
|
||||||
return do_ntranslate(singular, plural, number, 'ngettext')
|
return do_ntranslate(singular, plural, number, 'ngettext')
|
||||||
|
|
||||||
|
if six.PY3:
|
||||||
|
ungettext = ngettext
|
||||||
|
else:
|
||||||
def ungettext(singular, plural, number):
|
def ungettext(singular, plural, number):
|
||||||
"""
|
"""
|
||||||
Returns a unicode strings of the translation of either the singular or
|
Returns a unicode strings of the translation of either the singular or
|
||||||
|
@ -305,12 +312,12 @@ def ungettext(singular, plural, number):
|
||||||
return do_ntranslate(singular, plural, number, 'ungettext')
|
return do_ntranslate(singular, plural, number, 'ungettext')
|
||||||
|
|
||||||
def npgettext(context, singular, plural, number):
|
def npgettext(context, singular, plural, number):
|
||||||
result = do_ntranslate("%s%s%s" % (context, CONTEXT_SEPARATOR, singular),
|
result = ungettext("%s%s%s" % (context, CONTEXT_SEPARATOR, singular),
|
||||||
"%s%s%s" % (context, CONTEXT_SEPARATOR, plural),
|
"%s%s%s" % (context, CONTEXT_SEPARATOR, plural),
|
||||||
number, 'ungettext')
|
number)
|
||||||
if CONTEXT_SEPARATOR in result:
|
if CONTEXT_SEPARATOR in result:
|
||||||
# Translation not found
|
# Translation not found
|
||||||
result = do_ntranslate(singular, plural, number, 'ungettext')
|
result = ungettext(singular, plural, number)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def all_locale_paths():
|
def all_locale_paths():
|
||||||
|
@ -440,7 +447,7 @@ def templatize(src, origin=None):
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.template import (Lexer, TOKEN_TEXT, TOKEN_VAR, TOKEN_BLOCK,
|
from django.template import (Lexer, TOKEN_TEXT, TOKEN_VAR, TOKEN_BLOCK,
|
||||||
TOKEN_COMMENT, TRANSLATOR_COMMENT_MARK)
|
TOKEN_COMMENT, TRANSLATOR_COMMENT_MARK)
|
||||||
src = src.decode(settings.FILE_CHARSET)
|
src = smart_text(src, settings.FILE_CHARSET)
|
||||||
out = StringIO()
|
out = StringIO()
|
||||||
message_context = None
|
message_context = None
|
||||||
intrans = False
|
intrans = False
|
||||||
|
@ -455,7 +462,7 @@ def templatize(src, origin=None):
|
||||||
content = ''.join(comment)
|
content = ''.join(comment)
|
||||||
translators_comment_start = None
|
translators_comment_start = None
|
||||||
for lineno, line in enumerate(content.splitlines(True)):
|
for lineno, line in enumerate(content.splitlines(True)):
|
||||||
if line.lstrip().startswith(TRANSLATOR_COMMENT_MARK):
|
if line.lstrip().startswith(smart_text(TRANSLATOR_COMMENT_MARK)):
|
||||||
translators_comment_start = lineno
|
translators_comment_start = lineno
|
||||||
for lineno, line in enumerate(content.splitlines(True)):
|
for lineno, line in enumerate(content.splitlines(True)):
|
||||||
if translators_comment_start is not None and lineno >= translators_comment_start:
|
if translators_comment_start is not None and lineno >= translators_comment_start:
|
||||||
|
@ -570,7 +577,7 @@ def templatize(src, origin=None):
|
||||||
out.write(' # %s' % t.contents)
|
out.write(' # %s' % t.contents)
|
||||||
else:
|
else:
|
||||||
out.write(blankout(t.contents, 'X'))
|
out.write(blankout(t.contents, 'X'))
|
||||||
return out.getvalue().encode('utf-8')
|
return smart_str(out.getvalue())
|
||||||
|
|
||||||
def parse_accept_lang_header(lang_string):
|
def parse_accept_lang_header(lang_string):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in New Issue