Correct the fix for #10252: Popen objects have no close method.

This commit is contained in:
Éric Araujo 2010-11-06 15:57:52 +00:00
parent e7cf954247
commit 8bdbe9c52f
2 changed files with 20 additions and 15 deletions

View File

@ -377,7 +377,9 @@ def _find_exe_version(cmd):
try:
out_string = out.read()
finally:
out.close()
out.stdin.close()
out.stdout.close()
out.stderr.close()
result = RE_VERSION.search(out_string)
if result is None:
return None

View File

@ -267,21 +267,24 @@ def query_vcvarsall(version, arch="x86"):
stdout, stderr = popen.communicate()
if popen.wait() != 0:
raise DistutilsPlatformError(stderr.decode("mbcs"))
finally:
popen.close()
stdout = stdout.decode("mbcs")
for line in stdout.split("\n"):
line = Reg.convert_mbcs(line)
if '=' not in line:
continue
line = line.strip()
key, value = line.split('=', 1)
key = key.lower()
if key in interesting:
if value.endswith(os.pathsep):
value = value[:-1]
result[key] = removeDuplicates(value)
stdout = stdout.decode("mbcs")
for line in stdout.split("\n"):
line = Reg.convert_mbcs(line)
if '=' not in line:
continue
line = line.strip()
key, value = line.split('=', 1)
key = key.lower()
if key in interesting:
if value.endswith(os.pathsep):
value = value[:-1]
result[key] = removeDuplicates(value)
finally:
popen.stdin.close()
popen.stdout.close()
popen.stderr.close()
if len(result) != len(interesting):
raise ValueError(str(list(result.keys())))