Merge "Close inherited PIPE before doing work" into gingerbread

This commit is contained in:
Ying Wang 2011-03-15 17:49:04 -07:00 committed by Android (Google) Code Review
commit 080ed92e77
3 changed files with 19 additions and 0 deletions

View File

@ -18,6 +18,7 @@ import getopt
import getpass
import imp
import os
import platform
import re
import sha
import shutil
@ -57,6 +58,22 @@ def Run(args, **kwargs):
return subprocess.Popen(args, **kwargs)
def CloseInheritedPipes():
""" Gmake in MAC OS has file descriptor (PIPE) leak. We close those fds
before doing other work."""
if platform.system() != "Darwin":
return
for d in range(3, 1025):
try:
stat = os.fstat(d)
if stat is not None:
pipebit = stat[0] & 0x1000
if pipebit != 0:
os.close(d)
except OSError:
pass
def LoadInfoDict(zip):
"""Read and parse the META/misc_info.txt key/value pairs from the
input target files and return a dict."""

View File

@ -181,6 +181,7 @@ def main(argv):
if __name__ == '__main__':
try:
common.CloseInheritedPipes()
main(sys.argv[1:])
except common.ExternalError, e:
print

View File

@ -781,6 +781,7 @@ def main(argv):
if __name__ == '__main__':
try:
common.CloseInheritedPipes()
main(sys.argv[1:])
except common.ExternalError, e:
print