]> granicus.if.org Git - python/commitdiff
Closes #16112: platform.architecture does not correctly escape argument to /usr/bin...
authorJesus Cea <jcea@jcea.es>
Thu, 4 Oct 2012 11:51:43 +0000 (13:51 +0200)
committerJesus Cea <jcea@jcea.es>
Thu, 4 Oct 2012 11:51:43 +0000 (13:51 +0200)
Lib/platform.py
Misc/ACKS
Misc/NEWS

index 985a9f85cb05d7c9e8a6139686f56750aad5a9f1..6776a2515dbc296253471a4437d02b97b3658411 100755 (executable)
@@ -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:
index c42e32a1671ae65c2a12b07ad505aa86af5f981d..ca7431b2d183c6b4bfe9f9d9345ab64ce53306c4 100644 (file)
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -87,6 +87,7 @@ Ben Bell
 Thomas Bellman
 Alexander “Саша” Belopolsky
 Eli Bendersky
+David Benjamin
 Andrew Bennetts
 Andy Bensky
 Bennett Benson
index e7fc4f8ea4eb0ec651f779c988da3e3c5fce616f..bc5470aac9054e4489c0c57a3b0ada9936b13fa9 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -160,6 +160,9 @@ Library
 - Issue #15509: webbrowser.UnixBrowser no longer passes empty arguments to
   Popen when %action substitutions produce empty strings.
 
+- Issue #16112: platform.architecture does not correctly escape argument to
+  /usr/bin/file.  Patch by David Benjamin.
+
 - Issue #12776,#11839: call argparse type function (specified by add_argument)
   only once. Before, the type function was called twice in the case where the
   default was specified and the argument was given as well.  This was