diff options
author | Jason R. Coombs <jaraco@jaraco.com> | 2019-01-27 09:11:50 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-01-27 09:11:50 -0500 |
commit | b31997dbcd935ded39868b42d765830ad6e29808 (patch) | |
tree | c33f768bcfec750fb567100303aa30dae488acdb /setuptools/unicode_utils.py | |
parent | 5cd86987530892bfb01f68ad5f1a2b997a3d01e7 (diff) | |
parent | 249f24a1f04ce390a9e48a4d8a5bff7982714c86 (diff) | |
download | external_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.py | 13 |
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') |