Fix #1059: Linking for mingw/x86_64 on MSYS2 fails, and optimize "ar" command execution
parent
19c83a8837
commit
8ddee7d63b
|
@ -11,23 +11,12 @@ def configure(env):
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
def mySubProcess(cmdline, env):
|
def mySubProcess(cmdline, env):
|
||||||
# print "SPAWNED : " + cmdline
|
# print(cmdline)
|
||||||
startupinfo = subprocess.STARTUPINFO()
|
rv = subprocess.run(args=cmdline, shell=True, env=env).returncode
|
||||||
startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOW
|
|
||||||
proc = subprocess.Popen(
|
|
||||||
cmdline,
|
|
||||||
stdin=subprocess.PIPE,
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
stderr=subprocess.PIPE,
|
|
||||||
startupinfo=startupinfo,
|
|
||||||
shell=False,
|
|
||||||
env=env,
|
|
||||||
)
|
|
||||||
data, err = proc.communicate()
|
|
||||||
rv = proc.wait()
|
|
||||||
if rv:
|
if rv:
|
||||||
print("=====")
|
print("=====")
|
||||||
print(err.decode("utf-8"))
|
print("subprocess.run().returncode=", rv, "(", hex(rv), ")")
|
||||||
|
print("len(cmdline)=", len(cmdline))
|
||||||
print("=====")
|
print("=====")
|
||||||
return rv
|
return rv
|
||||||
|
|
||||||
|
@ -36,15 +25,27 @@ def configure(env):
|
||||||
cmdline = cmd + " " + newargs
|
cmdline = cmd + " " + newargs
|
||||||
|
|
||||||
rv = 0
|
rv = 0
|
||||||
if len(cmdline) > 32000 and cmd.endswith("ar"):
|
if len(args) > 4 and cmd.endswith("ar"):
|
||||||
cmdline = cmd + " " + args[1] + " " + args[2] + " "
|
# print("Long ar command is split.\nargc=", len(args))
|
||||||
for i in range(3, len(args)):
|
lead = len(" ".join(args[0:3]))
|
||||||
rv = mySubProcess(cmdline + args[i], env)
|
begin = 3
|
||||||
|
length = lead + 1 + len(args[begin])
|
||||||
|
for i in range(4, len(args)):
|
||||||
|
length += 1 + len(args[i])
|
||||||
|
if length > 8158:
|
||||||
|
cmdline = " ".join(args[0:3] + args[begin:i])
|
||||||
|
# print("objs=", i - begin, ", length=", len(cmdline))
|
||||||
|
rv = mySubProcess(cmdline, env)
|
||||||
if rv:
|
if rv:
|
||||||
break
|
break
|
||||||
else:
|
begin = i
|
||||||
|
length = lead + 1 + len(args[begin])
|
||||||
|
if not rv:
|
||||||
|
cmdline = " ".join(args[0:3] + args[begin:])
|
||||||
|
# print("objs=", len(args) - begin, ", length=", len(cmdline))
|
||||||
rv = mySubProcess(cmdline, env)
|
rv = mySubProcess(cmdline, env)
|
||||||
|
else:
|
||||||
|
rv = mySubProcess(" ".join(args), env)
|
||||||
return rv
|
return rv
|
||||||
|
|
||||||
env["SPAWN"] = mySpawn
|
env["SPAWN"] = mySpawn
|
||||||
|
|
Loading…
Reference in New Issue