diff options
author | Jesus Cea <jcea@jcea.es> | 2012-10-04 11:51:43 (GMT) |
---|---|---|
committer | Jesus Cea <jcea@jcea.es> | 2012-10-04 11:51:43 (GMT) |
commit | fc990e942fb55be78e8352f4913749e91cac381d (patch) | |
tree | 4df9256fdbd56a4097c36e88688ee17d37183bd5 /Lib | |
parent | cf45325b61e2eb3a2c83b9f869cf56684d6cb679 (diff) | |
download | cpython-fc990e942fb55be78e8352f4913749e91cac381d.zip cpython-fc990e942fb55be78e8352f4913749e91cac381d.tar.gz cpython-fc990e942fb55be78e8352f4913749e91cac381d.tar.bz2 |
Closes #16112: platform.architecture does not correctly escape argument to /usr/bin/file
Diffstat (limited to 'Lib')
-rwxr-xr-x | Lib/platform.py | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/Lib/platform.py b/Lib/platform.py index 985a9f8..6776a25 100755 --- a/Lib/platform.py +++ b/Lib/platform.py @@ -111,7 +111,7 @@ __copyright__ = """ __version__ = '1.0.7' -import sys, os, re +import sys, os, re, subprocess ### Globals & Constants @@ -995,13 +995,15 @@ 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: |