summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2011-05-19 19:42:47 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2011-05-19 19:42:47 (GMT)
commit9cf6d131411f1e9bca2f094137a970b711b664c4 (patch)
tree5ecdeaeb3124d157a04afab8ac6f94764a116383
parent975077a88912d723c7c3277f5abc8b7497f63e2a (diff)
downloadcpython-9cf6d131411f1e9bca2f094137a970b711b664c4.zip
cpython-9cf6d131411f1e9bca2f094137a970b711b664c4.tar.gz
cpython-9cf6d131411f1e9bca2f094137a970b711b664c4.tar.bz2
Issue #12112: fix the encoding of setup.py in the packaging module
* read: use tokenize.detect_encoding() * write: use 'utf-8'
-rw-r--r--Lib/packaging/create.py5
-rw-r--r--Lib/packaging/util.py6
2 files changed, 7 insertions, 4 deletions
diff --git a/Lib/packaging/create.py b/Lib/packaging/create.py
index ca82773..5432ffc 100644
--- a/Lib/packaging/create.py
+++ b/Lib/packaging/create.py
@@ -32,6 +32,7 @@ import glob
import re
import shutil
import sysconfig
+import tokenize
from configparser import RawConfigParser
from textwrap import dedent
from hashlib import md5
@@ -116,7 +117,9 @@ def load_setup():
This function load the setup file in all cases (even if it have already
been loaded before, because we are monkey patching its setup function with
a particular one"""
- with open("setup.py") as f:
+ with open("setup.py", "rb") as f:
+ encoding, lines = tokenize.detect_encoding(f.readline)
+ with open("setup.py", encoding=encoding) as f:
imp.load_module("setup", f, "setup.py", (".py", "r", imp.PY_SOURCE))
diff --git a/Lib/packaging/util.py b/Lib/packaging/util.py
index 058f13e..71ce819 100644
--- a/Lib/packaging/util.py
+++ b/Lib/packaging/util.py
@@ -346,9 +346,9 @@ def byte_compile(py_files, optimize=0, force=False, prefix=None,
logger.info("writing byte-compilation script '%s'", script_name)
if not dry_run:
if script_fd is not None:
- script = os.fdopen(script_fd, "w")
+ script = os.fdopen(script_fd, "w", encoding='utf-8')
else:
- script = open(script_name, "w")
+ script = open(script_name, "w", encoding='utf-8')
with script:
script.write("""\
@@ -1087,7 +1087,7 @@ def generate_setup_py():
if os.path.exists("setup.py"):
raise PackagingFileError("a setup.py file alreadyexists")
- with open("setup.py", "w") as fp:
+ with open("setup.py", "w", encoding='utf-8') as fp:
fp.write(_SETUP_TMPL % {'func': getsource(cfg_to_args)})