mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	[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:
		| @@ -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')) | ||||||
|   | |||||||
| @@ -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): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user