diff options
author | Jesus Cea <jcea@jcea.es> | 2012-10-04 11:58:22 (GMT) |
---|---|---|
committer | Jesus Cea <jcea@jcea.es> | 2012-10-04 11:58:22 (GMT) |
commit | 677ffd16bf8ec440a22b65042293654c6a76095f (patch) | |
tree | a896c1a287dc1c68165290e9c45180a6e6ea573b | |
parent | dc469454ec997166aea062f5727a8d59bab2f7a0 (diff) | |
parent | e8801e2e44b4ffcfdfc6e2857e7afc90ba6abc38 (diff) | |
download | cpython-677ffd16bf8ec440a22b65042293654c6a76095f.zip cpython-677ffd16bf8ec440a22b65042293654c6a76095f.tar.gz cpython-677ffd16bf8ec440a22b65042293654c6a76095f.tar.bz2 |
MERGE: Closes #16112: platform.architecture does not correctly escape argument to /usr/bin/file
-rwxr-xr-x | Lib/platform.py | 13 | ||||
-rw-r--r-- | Misc/ACKS | 1 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 12 insertions, 5 deletions
diff --git a/Lib/platform.py b/Lib/platform.py index b653822..dd318fe 100755 --- a/Lib/platform.py +++ b/Lib/platform.py @@ -112,7 +112,7 @@ __copyright__ = """ __version__ = '1.0.7' import collections -import sys, os, re +import sys, os, re, subprocess ### Globals & Constants @@ -922,13 +922,16 @@ def _syscmd_file(target,default=''): if sys.platform in ('dos','win32','win16','os2'): # XXX Others too ? return default - target = _follow_symlinks(target).replace('"', '\\"') + target = _follow_symlinks(target) try: - f = os.popen('file -b "%s" 2> %s' % (target, DEV_NULL)) + with open(DEV_NULL) as dev_null: + proc = subprocess.Popen(['file', '-b', '--', target], + stdout=subprocess.PIPE, stderr=dev_null) + except (AttributeError,os.error): return default - output = f.read().strip() - rc = f.close() + output = proc.stdout.read() + rc = proc.wait() if not output or rc: return default else: @@ -93,6 +93,7 @@ Ben Bell Thomas Bellman Alexander “Саша” Belopolsky Eli Bendersky +David Benjamin Andrew Bennetts Andy Bensky Bennett Benson @@ -65,6 +65,9 @@ Library - Issue #15421: Fix an OverflowError in `Calendar.itermonthdates()` after `datetime.MAXYEAR`. Patch by Cédric Krier. +- Issue #16112: platform.architecture does not correctly escape argument to + /usr/bin/file. Patch by David Benjamin. + - Issue #15970: `xml.etree.ElementTree` now serializes correctly the empty HTML elements 'meta' and 'param'. |