summaryrefslogtreecommitdiff
path: root/Lib/platform.py
diff options
context:
space:
mode:
authorJesus Cea <jcea@jcea.es>2012-10-04 13:46:33 +0200
committerJesus Cea <jcea@jcea.es>2012-10-04 13:46:33 +0200
commit95038fa526c8b93e42c59b0735edf1c80b7b6449 (patch)
treea449a7e3a1ac60faa8ec5e56f1ca34d7038f40b2 /Lib/platform.py
parent7c0a87f211ab800cefd1eb273f69967c5fc23f66 (diff)
downloadcpython-git-95038fa526c8b93e42c59b0735edf1c80b7b6449.tar.gz
Closes #16112: platform.architecture does not correctly escape argument to /usr/bin/file
Diffstat (limited to 'Lib/platform.py')
-rwxr-xr-xLib/platform.py13
1 files changed, 8 insertions, 5 deletions
diff --git a/Lib/platform.py b/Lib/platform.py
index d20c39d9a7..e94a32aab7 100755
--- a/Lib/platform.py
+++ b/Lib/platform.py
@@ -113,7 +113,7 @@ __copyright__ = """
__version__ = '1.0.7'
-import sys,string,os,re
+import sys,string,os,re,subprocess
### Globals & Constants
@@ -1023,13 +1023,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 "%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 = string.strip(f.read())
- rc = f.close()
+ output = proc.stdout.read()
+ rc = proc.wait()
if not output or rc:
return default
else: