From 72de42cd401613197902370c812eaf607244d87c Mon Sep 17 00:00:00 2001 From: Claude Paroz Date: Wed, 1 Apr 2015 18:37:47 +0200 Subject: [PATCH] [1.8.x] Refs #24500 -- Avoided locale.getpreferredencoding in makemessages Fixes a regression introduced in 53c2cf1e. Backport of 3f4e77840 from master. --- django/core/management/commands/makemessages.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/django/core/management/commands/makemessages.py b/django/core/management/commands/makemessages.py index fb1f2ffe829..d1287bd4339 100644 --- a/django/core/management/commands/makemessages.py +++ b/django/core/management/commands/makemessages.py @@ -3,7 +3,6 @@ from __future__ import unicode_literals import fnmatch import glob import io -import locale import os import re import sys @@ -17,7 +16,7 @@ from django.core.management.utils import ( ) from django.utils import six from django.utils._os import upath -from django.utils.encoding import force_str +from django.utils.encoding import DEFAULT_LOCALE_ENCODING, force_str from django.utils.functional import cached_property, total_ordering from django.utils.jslex import prepare_js_for_gettext from django.utils.text import get_text_list @@ -38,14 +37,13 @@ def gettext_popen_wrapper(args, os_err_exc_type=CommandError, stdout_encoding="u Makes sure text obtained from stdout of gettext utilities is Unicode. """ stdout, stderr, status_code = popen_wrapper(args, os_err_exc_type=os_err_exc_type) - preferred_encoding = locale.getpreferredencoding(False) - if os.name == 'nt' and six.PY3 and stdout_encoding != preferred_encoding: + if os.name == 'nt' and six.PY3 and stdout_encoding != DEFAULT_LOCALE_ENCODING: # This looks weird because it's undoing what # subprocess.Popen(universal_newlines=True).communicate() # does when capturing PO files contents from stdout of gettext command # line programs. No need to do anything on Python 2 because it's # already a byte-string there (#23271). - stdout = stdout.encode(preferred_encoding).decode(stdout_encoding) + stdout = stdout.encode(DEFAULT_LOCALE_ENCODING).decode(stdout_encoding) if six.PY2: stdout = stdout.decode(stdout_encoding) return stdout, stderr, status_code @@ -332,7 +330,7 @@ class Command(BaseCommand): # when looking up the version. It's especially a problem on Windows. out, err, status = gettext_popen_wrapper( ['xgettext', '--version'], - stdout_encoding=locale.getpreferredencoding(False), + stdout_encoding=DEFAULT_LOCALE_ENCODING, ) m = re.search(r'(\d+)\.(\d+)\.?(\d+)?', out) if m: