|
@@ -170,7 +170,7 @@ opts.Add(EnumVariable("arch", "CPU architecture", "auto", ["auto"] + architectur
|
|
opts.Add(EnumVariable("float", "Floating-point precision", "32", ("32", "64")))
|
|
opts.Add(EnumVariable("float", "Floating-point precision", "32", ("32", "64")))
|
|
opts.Add(EnumVariable("optimize", "Optimization type", "speed", ("speed", "size", "none")))
|
|
opts.Add(EnumVariable("optimize", "Optimization type", "speed", ("speed", "size", "none")))
|
|
opts.Add(BoolVariable("production", "Set defaults to build Godot for use in production", False))
|
|
opts.Add(BoolVariable("production", "Set defaults to build Godot for use in production", False))
|
|
-opts.Add(EnumVariable("lto", "Link-time optimization (for production buids)", "none", ("none", "thin", "full")))
|
|
|
|
|
|
+opts.Add(EnumVariable("lto", "Link-time optimization (for production buids)", "none", ("none", "auto", "thin", "full")))
|
|
|
|
|
|
# Components
|
|
# Components
|
|
opts.Add(BoolVariable("deprecated", "Enable compatibility code for deprecated and removed features", True))
|
|
opts.Add(BoolVariable("deprecated", "Enable compatibility code for deprecated and removed features", True))
|
|
@@ -460,36 +460,17 @@ if selected_platform in platform_list:
|
|
env["LINKFLAGS"] = ""
|
|
env["LINKFLAGS"] = ""
|
|
env.Append(LINKFLAGS=str(LINKFLAGS).split())
|
|
env.Append(LINKFLAGS=str(LINKFLAGS).split())
|
|
|
|
|
|
- # Platform specific flags
|
|
|
|
|
|
+ # Platform specific flags.
|
|
|
|
+ # These can sometimes override default options.
|
|
flag_list = platform_flags[selected_platform]
|
|
flag_list = platform_flags[selected_platform]
|
|
for f in flag_list:
|
|
for f in flag_list:
|
|
if not (f[0] in ARGUMENTS) or ARGUMENTS[f[0]] == "auto": # Allow command line to override platform flags
|
|
if not (f[0] in ARGUMENTS) or ARGUMENTS[f[0]] == "auto": # Allow command line to override platform flags
|
|
env[f[0]] = f[1]
|
|
env[f[0]] = f[1]
|
|
|
|
|
|
- # Must happen after the flags' definition, so that they can be used by platform detect
|
|
|
|
- detect.configure(env)
|
|
|
|
-
|
|
|
|
- print(
|
|
|
|
- 'Building for platform "%s", architecture "%s", %s, target "%s".'
|
|
|
|
- % (selected_platform, env["arch"], "editor" if env["tools"] else "template", env["target"])
|
|
|
|
- )
|
|
|
|
-
|
|
|
|
- # Set our C and C++ standard requirements.
|
|
|
|
- # C++17 is required as we need guaranteed copy elision as per GH-36436.
|
|
|
|
- # Prepending to make it possible to override.
|
|
|
|
- # This needs to come after `configure`, otherwise we don't have env.msvc.
|
|
|
|
- if not env.msvc:
|
|
|
|
- # Specifying GNU extensions support explicitly, which are supported by
|
|
|
|
- # both GCC and Clang. Both currently default to gnu11 and gnu++14.
|
|
|
|
- env.Prepend(CFLAGS=["-std=gnu11"])
|
|
|
|
- env.Prepend(CXXFLAGS=["-std=gnu++17"])
|
|
|
|
- else:
|
|
|
|
- # MSVC doesn't have clear C standard support, /std only covers C++.
|
|
|
|
- # We apply it to CCFLAGS (both C and C++ code) in case it impacts C features.
|
|
|
|
- env.Prepend(CCFLAGS=["/std:c++17"])
|
|
|
|
-
|
|
|
|
- # 'dev' and 'production' are aliases to set default options if they haven't been set
|
|
|
|
- # manually by the user.
|
|
|
|
|
|
+ # 'dev' and 'production' are aliases to set default options if they haven't been
|
|
|
|
+ # set manually by the user.
|
|
|
|
+ # These need to be checked *after* platform specific flags so that different
|
|
|
|
+ # default values can be set (e.g. to keep LTO off for `production` on some platforms).
|
|
if env["dev"]:
|
|
if env["dev"]:
|
|
env["verbose"] = methods.get_cmdline_bool("verbose", True)
|
|
env["verbose"] = methods.get_cmdline_bool("verbose", True)
|
|
env["warnings"] = ARGUMENTS.get("warnings", "extra")
|
|
env["warnings"] = ARGUMENTS.get("warnings", "extra")
|
|
@@ -498,27 +479,43 @@ if selected_platform in platform_list:
|
|
env["tests"] = methods.get_cmdline_bool("tests", True)
|
|
env["tests"] = methods.get_cmdline_bool("tests", True)
|
|
if env["production"]:
|
|
if env["production"]:
|
|
env["use_static_cpp"] = methods.get_cmdline_bool("use_static_cpp", True)
|
|
env["use_static_cpp"] = methods.get_cmdline_bool("use_static_cpp", True)
|
|
- env["lto"] = ARGUMENTS.get("lto", "full")
|
|
|
|
env["debug_symbols"] = methods.get_cmdline_bool("debug_symbols", False)
|
|
env["debug_symbols"] = methods.get_cmdline_bool("debug_symbols", False)
|
|
|
|
+ # LTO "auto" means we handle the preferred option in each platform detect.py.
|
|
|
|
+ env["lto"] = ARGUMENTS.get("lto", "auto")
|
|
if not env["tools"] and env["target"] == "debug":
|
|
if not env["tools"] and env["target"] == "debug":
|
|
print(
|
|
print(
|
|
"WARNING: Requested `production` build with `tools=no target=debug`, "
|
|
"WARNING: Requested `production` build with `tools=no target=debug`, "
|
|
"this will give you a full debug template (use `target=release_debug` "
|
|
"this will give you a full debug template (use `target=release_debug` "
|
|
"for an optimized template with debug features)."
|
|
"for an optimized template with debug features)."
|
|
)
|
|
)
|
|
- if env.msvc:
|
|
|
|
- print(
|
|
|
|
- "WARNING: For `production` Windows builds, you should use MinGW with GCC "
|
|
|
|
- "or Clang instead of Visual Studio, as they can better optimize the "
|
|
|
|
- "GDScript VM in a very significant way. MSVC LTO also doesn't work "
|
|
|
|
- "reliably for our use case."
|
|
|
|
- "If you want to use MSVC nevertheless for production builds, set "
|
|
|
|
- "`debug_symbols=no lto=none` instead of the `production=yes` option."
|
|
|
|
- )
|
|
|
|
- Exit(255)
|
|
|
|
|
|
+
|
|
|
|
+ # Must happen after the flags' definition, as configure is when most flags
|
|
|
|
+ # are actually handled to change compile options, etc.
|
|
|
|
+ detect.configure(env)
|
|
|
|
+
|
|
|
|
+ # Needs to happen after configure to handle "auto".
|
|
if env["lto"] != "none":
|
|
if env["lto"] != "none":
|
|
print("Using LTO: " + env["lto"])
|
|
print("Using LTO: " + env["lto"])
|
|
|
|
|
|
|
|
+ # Set our C and C++ standard requirements.
|
|
|
|
+ # C++17 is required as we need guaranteed copy elision as per GH-36436.
|
|
|
|
+ # Prepending to make it possible to override.
|
|
|
|
+ # This needs to come after `configure`, otherwise we don't have env.msvc.
|
|
|
|
+ if not env.msvc:
|
|
|
|
+ # Specifying GNU extensions support explicitly, which are supported by
|
|
|
|
+ # both GCC and Clang. Both currently default to gnu11 and gnu++14.
|
|
|
|
+ env.Prepend(CFLAGS=["-std=gnu11"])
|
|
|
|
+ env.Prepend(CXXFLAGS=["-std=gnu++17"])
|
|
|
|
+ else:
|
|
|
|
+ # MSVC doesn't have clear C standard support, /std only covers C++.
|
|
|
|
+ # We apply it to CCFLAGS (both C and C++ code) in case it impacts C features.
|
|
|
|
+ env.Prepend(CCFLAGS=["/std:c++17"])
|
|
|
|
+
|
|
|
|
+ print(
|
|
|
|
+ 'Building for platform "%s", architecture "%s", %s, target "%s".'
|
|
|
|
+ % (selected_platform, env["arch"], "editor" if env["tools"] else "template", env["target"])
|
|
|
|
+ )
|
|
|
|
+
|
|
# Enforce our minimal compiler version requirements
|
|
# Enforce our minimal compiler version requirements
|
|
cc_version = methods.get_compiler_version(env) or {
|
|
cc_version = methods.get_compiler_version(env) or {
|
|
"major": None,
|
|
"major": None,
|