[1.7.x] Applied unicode_literals to makemessages command

This also fixes #22686 as some sort of side-effect.
Backport of dbb48d2bb9 from master.
This commit is contained in:
Claude Paroz 2014-05-24 11:51:57 +02:00
parent e692c5818b
commit cdfefbec72
2 changed files with 20 additions and 11 deletions

View File

@ -1,3 +1,5 @@
from __future__ import unicode_literals
import fnmatch import fnmatch
import glob import glob
import io import io
@ -56,6 +58,7 @@ class TranslatableFile(object):
Uses the xgettext GNU gettext utility. Uses the xgettext GNU gettext utility.
""" """
from django.conf import settings
from django.utils.translation import templatize from django.utils.translation import templatize
if command.verbosity > 1: if command.verbosity > 1:
@ -64,12 +67,12 @@ class TranslatableFile(object):
if domain == 'djangojs' and file_ext in command.extensions: if domain == 'djangojs' and file_ext in command.extensions:
is_templatized = True is_templatized = True
orig_file = os.path.join(self.dirpath, self.file) orig_file = os.path.join(self.dirpath, self.file)
with open(orig_file) as fp: with io.open(orig_file, encoding=settings.FILE_CHARSET) as fp:
src_data = fp.read() src_data = fp.read()
src_data = prepare_js_for_gettext(src_data) src_data = prepare_js_for_gettext(src_data)
thefile = '%s.c' % self.file thefile = '%s.c' % self.file
work_file = os.path.join(self.dirpath, thefile) work_file = os.path.join(self.dirpath, thefile)
with open(work_file, "w") as fp: with io.open(work_file, "w", encoding='utf-8') as fp:
fp.write(src_data) fp.write(src_data)
args = [ args = [
'xgettext', 'xgettext',
@ -88,11 +91,11 @@ class TranslatableFile(object):
orig_file = os.path.join(self.dirpath, self.file) orig_file = os.path.join(self.dirpath, self.file)
is_templatized = file_ext in command.extensions is_templatized = file_ext in command.extensions
if is_templatized: if is_templatized:
with open(orig_file, 'r' if six.PY3 else 'rU') as fp: with io.open(orig_file, 'r', encoding=settings.FILE_CHARSET) as fp:
src_data = fp.read() src_data = fp.read()
thefile = '%s.py' % self.file thefile = '%s.py' % self.file
content = templatize(src_data, orig_file[2:]) content = templatize(src_data, orig_file[2:])
with open(os.path.join(self.dirpath, thefile), "w") as fp: with io.open(os.path.join(self.dirpath, thefile), "w", encoding='utf-8') as fp:
fp.write(content) fp.write(content)
work_file = os.path.join(self.dirpath, thefile) work_file = os.path.join(self.dirpath, thefile)
args = [ args = [
@ -126,6 +129,8 @@ class TranslatableFile(object):
# Print warnings # Print warnings
command.stdout.write(errors) command.stdout.write(errors)
if msgs: if msgs:
if six.PY2:
msgs = msgs.decode('utf-8')
# Write/append messages to pot file # Write/append messages to pot file
potfile = os.path.join(self.locale_dir, '%s.pot' % str(domain)) potfile = os.path.join(self.locale_dir, '%s.pot' % str(domain))
if is_templatized: if is_templatized:
@ -154,7 +159,7 @@ def write_pot_file(potfile, msgs):
msgs = '\n'.join(dropwhile(len, msgs.split('\n'))) msgs = '\n'.join(dropwhile(len, msgs.split('\n')))
else: else:
msgs = msgs.replace('charset=CHARSET', 'charset=UTF-8') msgs = msgs.replace('charset=CHARSET', 'charset=UTF-8')
with open(potfile, 'a') as fp: with io.open(potfile, 'a', encoding='utf-8') as fp:
fp.write(msgs) fp.write(msgs)
@ -311,13 +316,15 @@ class Command(NoArgsCommand):
continue continue
args = ['msguniq'] + self.msguniq_options + [potfile] args = ['msguniq'] + self.msguniq_options + [potfile]
msgs, errors, status = popen_wrapper(args) msgs, errors, status = popen_wrapper(args)
if six.PY2:
msgs = msgs.decode('utf-8')
if errors: if errors:
if status != STATUS_OK: if status != STATUS_OK:
raise CommandError( raise CommandError(
"errors happened while running msguniq\n%s" % errors) "errors happened while running msguniq\n%s" % errors)
elif self.verbosity > 0: elif self.verbosity > 0:
self.stdout.write(errors) self.stdout.write(errors)
with open(potfile, 'w') as fp: with io.open(potfile, 'w', encoding='utf-8') as fp:
fp.write(msgs) fp.write(msgs)
potfiles.append(potfile) potfiles.append(potfile)
return potfiles return potfiles
@ -388,6 +395,8 @@ class Command(NoArgsCommand):
if os.path.exists(pofile): if os.path.exists(pofile):
args = ['msgmerge'] + self.msgmerge_options + [pofile, potfile] args = ['msgmerge'] + self.msgmerge_options + [pofile, potfile]
msgs, errors, status = popen_wrapper(args) msgs, errors, status = popen_wrapper(args)
if six.PY2:
msgs = msgs.decode('utf-8')
if errors: if errors:
if status != STATUS_OK: if status != STATUS_OK:
raise CommandError( raise CommandError(
@ -395,13 +404,13 @@ class Command(NoArgsCommand):
elif self.verbosity > 0: elif self.verbosity > 0:
self.stdout.write(errors) self.stdout.write(errors)
else: else:
with open(potfile, 'r') as fp: with io.open(potfile, 'r', encoding='utf-8') as fp:
msgs = fp.read() msgs = fp.read()
if not self.invoked_for_django: if not self.invoked_for_django:
msgs = self.copy_plural_forms(msgs, locale) msgs = self.copy_plural_forms(msgs, locale)
msgs = msgs.replace( msgs = msgs.replace(
"#. #-#-#-#-# %s.pot (PACKAGE VERSION) #-#-#-#-#\n" % self.domain, "") "#. #-#-#-#-# %s.pot (PACKAGE VERSION) #-#-#-#-#\n" % self.domain, "")
with open(pofile, 'w') as fp: with io.open(pofile, 'w', encoding='utf-8') as fp:
fp.write(msgs) fp.write(msgs)
if self.no_obsolete: if self.no_obsolete:
@ -428,7 +437,7 @@ class Command(NoArgsCommand):
for domain in domains: for domain in domains:
django_po = os.path.join(django_dir, 'conf', 'locale', locale, 'LC_MESSAGES', '%s.po' % domain) django_po = os.path.join(django_dir, 'conf', 'locale', locale, 'LC_MESSAGES', '%s.po' % domain)
if os.path.exists(django_po): if os.path.exists(django_po):
with io.open(django_po, 'r' if six.PY3 else 'rU', encoding='utf-8') as fp: with io.open(django_po, 'r', encoding='utf-8') as fp:
m = plural_forms_re.search(fp.read()) m = plural_forms_re.search(fp.read())
if m: if m:
plural_form_line = force_str(m.group('value')) plural_form_line = force_str(m.group('value'))

View File

@ -13,7 +13,7 @@ from django.apps import apps
from django.dispatch import receiver from django.dispatch import receiver
from django.test.signals import setting_changed from django.test.signals import setting_changed
from django.utils.deprecation import RemovedInDjango19Warning from django.utils.deprecation import RemovedInDjango19Warning
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils._os import upath from django.utils._os import upath
from django.utils.safestring import mark_safe, SafeData from django.utils.safestring import mark_safe, SafeData
from django.utils import six, lru_cache from django.utils import six, lru_cache
@ -715,7 +715,7 @@ def templatize(src, origin=None):
comment_lineno_cache = t.lineno comment_lineno_cache = t.lineno
else: else:
out.write(blankout(t.contents, 'X')) out.write(blankout(t.contents, 'X'))
return force_str(out.getvalue()) return out.getvalue()
def parse_accept_lang_header(lang_string): def parse_accept_lang_header(lang_string):