aboutsummaryrefslogtreecommitdiffstats
path: root/setuptools/unicode_utils.py
diff options
context:
space:
mode:
authorJason R. Coombs <jaraco@jaraco.com>2019-01-27 09:11:50 -0500
committerGitHub <noreply@github.com>2019-01-27 09:11:50 -0500
commitb31997dbcd935ded39868b42d765830ad6e29808 (patch)
treec33f768bcfec750fb567100303aa30dae488acdb /setuptools/unicode_utils.py
parent5cd86987530892bfb01f68ad5f1a2b997a3d01e7 (diff)
parent249f24a1f04ce390a9e48a4d8a5bff7982714c86 (diff)
downloadexternal_python_setuptools-b31997dbcd935ded39868b42d765830ad6e29808.tar.gz
external_python_setuptools-b31997dbcd935ded39868b42d765830ad6e29808.tar.bz2
external_python_setuptools-b31997dbcd935ded39868b42d765830ad6e29808.zip
Merge pull request #1180 from benoit-pierre/fix_889_and_non-ascii_in_setup.cfg_take_2
improve encoding handling for `setup.cfg`
Diffstat (limited to 'setuptools/unicode_utils.py')
-rw-r--r--setuptools/unicode_utils.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/setuptools/unicode_utils.py b/setuptools/unicode_utils.py
index 7c63efd2..3b8179a8 100644
--- a/setuptools/unicode_utils.py
+++ b/setuptools/unicode_utils.py
@@ -1,5 +1,6 @@
import unicodedata
import sys
+import re
from setuptools.extern import six
@@ -42,3 +43,15 @@ def try_encode(string, enc):
return string.encode(enc)
except UnicodeEncodeError:
return None
+
+
+CODING_RE = re.compile(br'^[ \t\f]*#.*?coding[:=][ \t]*([-\w.]+)')
+
+
+def detect_encoding(fp):
+ first_line = fp.readline()
+ fp.seek(0)
+ m = CODING_RE.match(first_line)
+ if m is None:
+ return None
+ return m.group(1).decode('ascii')