Revert "Implement "get_mingw_tool" to fix mingw prefixes"

This reverts commits ecebe0b40d
and 15d37ed2a8.

Fixes #91710.
This commit is contained in:
Rémi Verschelde 2024-05-09 11:09:28 +02:00
parent c4279fe3e0
commit 8a57f64255
No known key found for this signature in database
GPG key ID: C3336907360768E1
2 changed files with 77 additions and 54 deletions

View file

@ -18,30 +18,36 @@ def get_name():
return "Windows" return "Windows"
def get_mingw_tool(tool, prefix="", arch="", test="--version"): def try_cmd(test, prefix, arch):
if not prefix: if arch:
prefix = os.getenv("MINGW_PREFIX", "")
supported_arches = ["x86_64", "x86_32", "arm64", "arm32"]
if arch in supported_arches:
arches = [arch, ""]
else:
arches = ["x86_64", "x86_32", "arm64", "arm32", ""]
for a in arches:
try: try:
path = f"{get_mingw_bin_prefix(prefix, a)}{tool}"
out = subprocess.Popen( out = subprocess.Popen(
f"{path} {test}", get_mingw_bin_prefix(prefix, arch) + test,
shell=True, shell=True,
stderr=subprocess.PIPE, stderr=subprocess.PIPE,
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
) )
out.communicate() out.communicate()
if out.returncode == 0: if out.returncode == 0:
return path return True
except Exception: except Exception:
pass pass
else:
for a in ["x86_64", "x86_32", "arm64", "arm32"]:
try:
out = subprocess.Popen(
get_mingw_bin_prefix(prefix, a) + test,
shell=True,
stderr=subprocess.PIPE,
stdout=subprocess.PIPE,
)
out.communicate()
if out.returncode == 0:
return True
except Exception:
pass
return "" return False
def can_build(): def can_build():
@ -59,7 +65,9 @@ def can_build():
if os.name == "posix": if os.name == "posix":
# Cross-compiling with MinGW-w64 (old MinGW32 is not supported) # Cross-compiling with MinGW-w64 (old MinGW32 is not supported)
if get_mingw_tool("gcc") or get_mingw_tool("clang"): prefix = os.getenv("MINGW_PREFIX", "")
if try_cmd("gcc --version", prefix, "") or try_cmd("clang --version", prefix, ""):
return True return True
return False return False
@ -247,26 +255,36 @@ def get_flags():
def build_res_file(target, source, env: "SConsEnvironment"): def build_res_file(target, source, env: "SConsEnvironment"):
cmdbase = get_mingw_tool("windres", env["mingw_prefix"], env["arch"])
if not cmdbase:
return -1
arch_aliases = { arch_aliases = {
"x86_32": "pe-i386", "x86_32": "pe-i386",
"x86_64": "pe-x86-64", "x86_64": "pe-x86-64",
"arm32": "armv7-w64-mingw32", "arm32": "armv7-w64-mingw32",
"arm64": "aarch64-w64-mingw32", "arm64": "aarch64-w64-mingw32",
} }
cmdbase += " --include-dir . --target=" + arch_aliases[env["arch"]] cmdbase = "windres --include-dir . --target=" + arch_aliases[env["arch"]]
mingw_bin_prefix = get_mingw_bin_prefix(env["mingw_prefix"], env["arch"])
for x in range(len(source)): for x in range(len(source)):
cmd = f"{cmdbase} -i {source[x]} -o {target[x]}" ok = True
# Try prefixed executable (MinGW on Linux).
cmd = mingw_bin_prefix + cmdbase + " -i " + str(source[x]) + " -o " + str(target[x])
try: try:
out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate() out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate()
if len(out[1]): if len(out[1]):
return -1 ok = False
except Exception: except Exception:
return -1 ok = False
# Try generic executable (MSYS2).
if not ok:
cmd = cmdbase + " -i " + str(source[x]) + " -o " + str(target[x])
try:
out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate()
if len(out[1]):
return -1
except Exception:
return -1
return 0 return 0
@ -340,8 +358,8 @@ def setup_mingw(env: "SConsEnvironment"):
) )
sys.exit(255) sys.exit(255)
if not get_mingw_tool("gcc", env["mingw_prefix"], env["arch"]) and not get_mingw_tool( if not try_cmd("gcc --version", env["mingw_prefix"], env["arch"]) and not try_cmd(
"clang", env["mingw_prefix"], env["arch"] "clang --version", env["mingw_prefix"], env["arch"]
): ):
print_error("No valid compilers found, use MINGW_PREFIX environment variable to set MinGW path.") print_error("No valid compilers found, use MINGW_PREFIX environment variable to set MinGW path.")
sys.exit(255) sys.exit(255)
@ -582,10 +600,10 @@ def configure_mingw(env: "SConsEnvironment"):
## Build type ## Build type
if not env["use_llvm"] and not get_mingw_tool("gcc", env["mingw_prefix"], env["arch"]): if not env["use_llvm"] and not try_cmd("gcc --version", env["mingw_prefix"], env["arch"]):
env["use_llvm"] = True env["use_llvm"] = True
if env["use_llvm"] and not get_mingw_tool("clang", env["mingw_prefix"], env["arch"]): if env["use_llvm"] and not try_cmd("clang --version", env["mingw_prefix"], env["arch"]):
env["use_llvm"] = False env["use_llvm"] = False
# TODO: Re-evaluate the need for this / streamline with common config. # TODO: Re-evaluate the need for this / streamline with common config.
@ -620,26 +638,27 @@ def configure_mingw(env: "SConsEnvironment"):
if env["arch"] in ["x86_32", "x86_64"]: if env["arch"] in ["x86_32", "x86_64"]:
env["x86_libtheora_opt_gcc"] = True env["x86_libtheora_opt_gcc"] = True
mingw_bin_prefix = get_mingw_bin_prefix(env["mingw_prefix"], env["arch"])
if env["use_llvm"]: if env["use_llvm"]:
env["CC"] = get_mingw_tool("clang", env["mingw_prefix"], env["arch"]) env["CC"] = mingw_bin_prefix + "clang"
env["CXX"] = get_mingw_tool("clang++", env["mingw_prefix"], env["arch"]) env["CXX"] = mingw_bin_prefix + "clang++"
tool_as = get_mingw_tool("as", env["mingw_prefix"], env["arch"]) if try_cmd("as --version", env["mingw_prefix"], env["arch"]):
tool_ar = get_mingw_tool("ar", env["mingw_prefix"], env["arch"]) env["AS"] = mingw_bin_prefix + "as"
tool_ranlib = get_mingw_tool("ranlib", env["mingw_prefix"], env["arch"]) if try_cmd("ar --version", env["mingw_prefix"], env["arch"]):
env["AR"] = mingw_bin_prefix + "ar"
if try_cmd("ranlib --version", env["mingw_prefix"], env["arch"]):
env["RANLIB"] = mingw_bin_prefix + "ranlib"
env.extra_suffix = ".llvm" + env.extra_suffix env.extra_suffix = ".llvm" + env.extra_suffix
else: else:
env["CC"] = get_mingw_tool("gcc", env["mingw_prefix"], env["arch"]) env["CC"] = mingw_bin_prefix + "gcc"
env["CXX"] = get_mingw_tool("g++", env["mingw_prefix"], env["arch"]) env["CXX"] = mingw_bin_prefix + "g++"
tool_as = get_mingw_tool("as", env["mingw_prefix"], env["arch"]) if try_cmd("as --version", env["mingw_prefix"], env["arch"]):
tool_ar = get_mingw_tool("gcc-ar", env["mingw_prefix"], env["arch"]) env["AS"] = mingw_bin_prefix + "as"
tool_ranlib = get_mingw_tool("gcc-ranlib", env["mingw_prefix"], env["arch"]) if try_cmd("gcc-ar --version", env["mingw_prefix"], env["arch"]):
env["AR"] = mingw_bin_prefix + "gcc-ar"
if tool_as: if try_cmd("gcc-ranlib --version", env["mingw_prefix"], env["arch"]):
env["AS"] = tool_as env["RANLIB"] = mingw_bin_prefix + "gcc-ranlib"
if tool_ar:
env["AR"] = tool_ar
if tool_ranlib:
env["RANLIB"] = tool_ranlib
## LTO ## LTO

View file

@ -1,20 +1,24 @@
"""Functions used to generate source files during build time""" """Functions used to generate source files during build time"""
import os import os
from detect import get_mingw_tool from detect import get_mingw_bin_prefix
from detect import try_cmd
def make_debug_mingw(target, source, env): def make_debug_mingw(target, source, env):
dst = str(target[0]) dst = str(target[0])
# Force separate debug symbols if executable size is larger than 1.9 GB. # Force separate debug symbols if executable size is larger than 1.9 GB.
if env["separate_debug_symbols"] or os.stat(dst).st_size >= 2040109465: if env["separate_debug_symbols"] or os.stat(dst).st_size >= 2040109465:
objcopy = get_mingw_tool("objcopy", env["mingw_prefix"], env["arch"]) mingw_bin_prefix = get_mingw_bin_prefix(env["mingw_prefix"], env["arch"])
strip = get_mingw_tool("strip", env["mingw_prefix"], env["arch"]) if try_cmd("objcopy --version", env["mingw_prefix"], env["arch"]):
os.system(mingw_bin_prefix + "objcopy --only-keep-debug {0} {0}.debugsymbols".format(dst))
if not objcopy or not strip: else:
print('`separate_debug_symbols` requires both "objcopy" and "strip" to function.') os.system("objcopy --only-keep-debug {0} {0}.debugsymbols".format(dst))
return if try_cmd("strip --version", env["mingw_prefix"], env["arch"]):
os.system(mingw_bin_prefix + "strip --strip-debug --strip-unneeded {0}".format(dst))
os.system("{0} --only-keep-debug {1} {1}.debugsymbols".format(objcopy, dst)) else:
os.system("{0} --strip-debug --strip-unneeded {1}".format(strip, dst)) os.system("strip --strip-debug --strip-unneeded {0}".format(dst))
os.system("{0} --add-gnu-debuglink={1}.debugsymbols {1}".format(objcopy, dst)) if try_cmd("objcopy --version", env["mingw_prefix"], env["arch"]):
os.system(mingw_bin_prefix + "objcopy --add-gnu-debuglink={0}.debugsymbols {0}".format(dst))
else:
os.system("objcopy --add-gnu-debuglink={0}.debugsymbols {0}".format(dst))