2014-02-10 02:10:30 +01:00
|
|
|
import os
|
|
|
|
import sys
|
2023-09-20 10:03:44 +02:00
|
|
|
from methods import detect_darwin_sdk_path, get_compiler_version, is_vanilla_clang
|
2023-12-11 19:50:44 +01:00
|
|
|
from platform_methods import detect_arch, detect_mvk
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2022-08-23 15:21:46 +02:00
|
|
|
from typing import TYPE_CHECKING
|
|
|
|
|
|
|
|
if TYPE_CHECKING:
|
2023-11-24 20:31:05 +01:00
|
|
|
from SCons.Script.SConscript import SConsEnvironment
|
2022-08-23 15:21:46 +02:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
|
|
|
|
def get_name():
|
2022-07-20 08:28:22 +02:00
|
|
|
return "macOS"
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-10-30 19:05:14 +01:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
def can_build():
|
2020-03-30 08:28:32 +02:00
|
|
|
if sys.platform == "darwin" or ("OSXCROSS_ROOT" in os.environ):
|
2016-10-30 18:44:57 +01:00
|
|
|
return True
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-10-30 18:44:57 +01:00
|
|
|
return False
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-10-30 19:05:14 +01:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
def get_opts():
|
2018-01-26 21:39:08 +01:00
|
|
|
from SCons.Variables import BoolVariable, EnumVariable
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-10-30 18:44:57 +01:00
|
|
|
return [
|
2020-07-20 20:30:40 +02:00
|
|
|
("osxcross_sdk", "OSXCross SDK version", "darwin16"),
|
2020-03-30 08:28:32 +02:00
|
|
|
("MACOS_SDK_PATH", "Path to the macOS SDK", ""),
|
2022-07-03 14:58:07 +02:00
|
|
|
("vulkan_sdk_path", "Path to the Vulkan SDK", ""),
|
2020-12-16 16:29:32 +01:00
|
|
|
EnumVariable("macports_clang", "Build using Clang from MacPorts", "no", ("no", "5.0", "devel")),
|
2020-03-30 08:28:32 +02:00
|
|
|
BoolVariable("use_ubsan", "Use LLVM/GCC compiler undefined behavior sanitizer (UBSAN)", False),
|
2020-08-01 08:35:37 +02:00
|
|
|
BoolVariable("use_asan", "Use LLVM/GCC compiler address sanitizer (ASAN)", False),
|
|
|
|
BoolVariable("use_tsan", "Use LLVM/GCC compiler thread sanitizer (TSAN)", False),
|
2021-10-29 00:00:19 +02:00
|
|
|
BoolVariable("use_coverage", "Use instrumentation codes in the binary (e.g. for code coverage)", False),
|
2021-11-12 13:49:49 +01:00
|
|
|
("angle_libs", "Path to the ANGLE static libraries", ""),
|
2023-12-11 19:50:44 +01:00
|
|
|
(
|
|
|
|
"bundle_sign_identity",
|
|
|
|
"The 'Full Name', 'Common Name' or SHA-1 hash of the signing identity used to sign editor .app bundle.",
|
|
|
|
"-",
|
|
|
|
),
|
|
|
|
BoolVariable("generate_bundle", "Generate an APP bundle after building iOS/macOS binaries", False),
|
2016-10-30 18:44:57 +01:00
|
|
|
]
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-10-30 19:05:14 +01:00
|
|
|
|
2023-04-19 11:23:22 +02:00
|
|
|
def get_doc_classes():
|
|
|
|
return [
|
|
|
|
"EditorExportPlatformMacOS",
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def get_doc_path():
|
|
|
|
return "doc_classes"
|
|
|
|
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
def get_flags():
|
2022-07-03 14:58:07 +02:00
|
|
|
return [
|
2021-12-16 02:38:10 +01:00
|
|
|
("arch", detect_arch()),
|
2022-07-03 14:58:07 +02:00
|
|
|
("use_volk", False),
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2023-11-24 20:31:05 +01:00
|
|
|
def configure(env: "SConsEnvironment"):
|
2021-12-16 02:38:10 +01:00
|
|
|
# Validate arch.
|
|
|
|
supported_arches = ["x86_64", "arm64"]
|
|
|
|
if env["arch"] not in supported_arches:
|
|
|
|
print(
|
|
|
|
'Unsupported CPU architecture "%s" for macOS. Supported architectures are: %s.'
|
|
|
|
% (env["arch"], ", ".join(supported_arches))
|
|
|
|
)
|
|
|
|
sys.exit()
|
|
|
|
|
2020-03-30 08:28:32 +02:00
|
|
|
## Build type
|
|
|
|
|
SCons: Unify tools/target build type configuration
Implements https://github.com/godotengine/godot-proposals/issues/3371.
New `target` presets
====================
The `tools` option is removed and `target` changes to use three new presets,
which match the builds users are familiar with. These targets control the
default optimization level and enable editor-specific and debugging code:
- `editor`: Replaces `tools=yes target=release_debug`.
* Defines: `TOOLS_ENABLED`, `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_debug`: Replaces `tools=no target=release_debug`.
* Defines: `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_release`: Replaces `tools=no target=release`.
* Defines: `-O3`/`/O2`
New `dev_build` option
======================
The previous `target=debug` is now replaced by a separate `dev_build=yes`
option, which can be used in combination with either of the three targets,
and changes the following:
- `dev_build`: Defines `DEV_ENABLED`, disables optimization (`-O0`/`/0d`),
enables generating debug symbols, does not define `NDEBUG` so `assert()`
works in thirdparty libraries, adds a `.dev` suffix to the binary name.
Note: Unlike previously, `dev_build` defaults to off so that users who
compile Godot from source get an optimized and small build by default.
Engine contributors should now set `dev_build=yes` in their build scripts or
IDE configuration manually.
Changed binary names
====================
The name of generated binaries and object files are changed too, to follow
this format:
`godot.<platform>.<target>[.dev][.double].<arch>[.<extra_suffix>][.<ext>]`
For example:
- `godot.linuxbsd.editor.dev.arm64`
- `godot.windows.template_release.double.x86_64.mono.exe`
Be sure to update your links/scripts/IDE config accordingly.
More flexible `optimize` and `debug_symbols` options
====================================================
The optimization level and whether to generate debug symbols can be further
specified with the `optimize` and `debug_symbols` options. So the default
values listed above for the various `target` and `dev_build` combinations
are indicative and can be replaced when compiling, e.g.:
`scons p=linuxbsd target=template_debug dev_build=yes optimize=debug`
will make a "debug" export template with dev-only code enabled, `-Og`
optimization level for GCC/Clang, and debug symbols. Perfect for debugging
complex crashes at runtime in an exported project.
2022-09-22 08:28:55 +02:00
|
|
|
if env["target"] == "template_release":
|
2020-07-24 16:54:34 +02:00
|
|
|
if env["arch"] != "arm64":
|
|
|
|
env.Prepend(CCFLAGS=["-msse2"])
|
SCons: Unify tools/target build type configuration
Implements https://github.com/godotengine/godot-proposals/issues/3371.
New `target` presets
====================
The `tools` option is removed and `target` changes to use three new presets,
which match the builds users are familiar with. These targets control the
default optimization level and enable editor-specific and debugging code:
- `editor`: Replaces `tools=yes target=release_debug`.
* Defines: `TOOLS_ENABLED`, `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_debug`: Replaces `tools=no target=release_debug`.
* Defines: `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_release`: Replaces `tools=no target=release`.
* Defines: `-O3`/`/O2`
New `dev_build` option
======================
The previous `target=debug` is now replaced by a separate `dev_build=yes`
option, which can be used in combination with either of the three targets,
and changes the following:
- `dev_build`: Defines `DEV_ENABLED`, disables optimization (`-O0`/`/0d`),
enables generating debug symbols, does not define `NDEBUG` so `assert()`
works in thirdparty libraries, adds a `.dev` suffix to the binary name.
Note: Unlike previously, `dev_build` defaults to off so that users who
compile Godot from source get an optimized and small build by default.
Engine contributors should now set `dev_build=yes` in their build scripts or
IDE configuration manually.
Changed binary names
====================
The name of generated binaries and object files are changed too, to follow
this format:
`godot.<platform>.<target>[.dev][.double].<arch>[.<extra_suffix>][.<ext>]`
For example:
- `godot.linuxbsd.editor.dev.arm64`
- `godot.windows.template_release.double.x86_64.mono.exe`
Be sure to update your links/scripts/IDE config accordingly.
More flexible `optimize` and `debug_symbols` options
====================================================
The optimization level and whether to generate debug symbols can be further
specified with the `optimize` and `debug_symbols` options. So the default
values listed above for the various `target` and `dev_build` combinations
are indicative and can be replaced when compiling, e.g.:
`scons p=linuxbsd target=template_debug dev_build=yes optimize=debug`
will make a "debug" export template with dev-only code enabled, `-Og`
optimization level for GCC/Clang, and debug symbols. Perfect for debugging
complex crashes at runtime in an exported project.
2022-09-22 08:28:55 +02:00
|
|
|
elif env.dev_build:
|
2020-08-15 02:55:36 +02:00
|
|
|
env.Prepend(LINKFLAGS=["-Xlinker", "-no_deduplicate"])
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2018-02-19 23:36:34 +01:00
|
|
|
## Compiler configuration
|
2017-06-30 19:21:38 +02:00
|
|
|
|
2018-12-22 12:31:43 +01:00
|
|
|
# Save this in environment for use by other modules
|
|
|
|
if "OSXCROSS_ROOT" in os.environ:
|
|
|
|
env["osxcross"] = True
|
|
|
|
|
2021-12-16 02:38:10 +01:00
|
|
|
# CPU architecture.
|
2020-07-20 20:30:40 +02:00
|
|
|
if env["arch"] == "arm64":
|
2021-12-16 02:38:10 +01:00
|
|
|
print("Building for macOS 11.0+.")
|
2022-07-01 10:29:21 +02:00
|
|
|
env.Append(ASFLAGS=["-arch", "arm64", "-mmacosx-version-min=11.0"])
|
2022-02-08 16:20:07 +01:00
|
|
|
env.Append(CCFLAGS=["-arch", "arm64", "-mmacosx-version-min=11.0"])
|
|
|
|
env.Append(LINKFLAGS=["-arch", "arm64", "-mmacosx-version-min=11.0"])
|
2021-12-16 02:38:10 +01:00
|
|
|
elif env["arch"] == "x86_64":
|
2023-04-24 09:52:50 +02:00
|
|
|
print("Building for macOS 10.13+.")
|
|
|
|
env.Append(ASFLAGS=["-arch", "x86_64", "-mmacosx-version-min=10.13"])
|
|
|
|
env.Append(CCFLAGS=["-arch", "x86_64", "-mmacosx-version-min=10.13"])
|
|
|
|
env.Append(LINKFLAGS=["-arch", "x86_64", "-mmacosx-version-min=10.13"])
|
2020-06-23 21:01:42 +02:00
|
|
|
|
2023-09-25 21:08:36 +02:00
|
|
|
cc_version = get_compiler_version(env)
|
2023-11-22 08:05:45 +01:00
|
|
|
cc_version_major = cc_version["apple_major"]
|
|
|
|
cc_version_minor = cc_version["apple_minor"]
|
2023-09-20 10:03:44 +02:00
|
|
|
vanilla = is_vanilla_clang(env)
|
|
|
|
|
|
|
|
# Workaround for Xcode 15 linker bug.
|
2023-11-22 08:05:45 +01:00
|
|
|
if not vanilla and cc_version_major == 1500 and cc_version_minor == 0:
|
2023-09-20 10:03:44 +02:00
|
|
|
env.Prepend(LINKFLAGS=["-ld_classic"])
|
|
|
|
|
2022-01-25 09:07:01 +01:00
|
|
|
env.Append(CCFLAGS=["-fobjc-arc"])
|
|
|
|
|
2020-07-20 20:30:40 +02:00
|
|
|
if not "osxcross" in env: # regular native build
|
2020-03-30 08:28:32 +02:00
|
|
|
if env["macports_clang"] != "no":
|
2017-12-14 15:15:06 +01:00
|
|
|
mpprefix = os.environ.get("MACPORTS_PREFIX", "/opt/local")
|
2017-12-14 19:41:50 +01:00
|
|
|
mpclangver = env["macports_clang"]
|
|
|
|
env["CC"] = mpprefix + "/libexec/llvm-" + mpclangver + "/bin/clang"
|
|
|
|
env["CXX"] = mpprefix + "/libexec/llvm-" + mpclangver + "/bin/clang++"
|
2020-03-30 08:28:32 +02:00
|
|
|
env["AR"] = mpprefix + "/libexec/llvm-" + mpclangver + "/bin/llvm-ar"
|
|
|
|
env["RANLIB"] = mpprefix + "/libexec/llvm-" + mpclangver + "/bin/llvm-ranlib"
|
|
|
|
env["AS"] = mpprefix + "/libexec/llvm-" + mpclangver + "/bin/llvm-as"
|
2019-10-24 16:34:18 +02:00
|
|
|
else:
|
2020-03-30 08:28:32 +02:00
|
|
|
env["CC"] = "clang"
|
|
|
|
env["CXX"] = "clang++"
|
2017-06-30 19:21:38 +02:00
|
|
|
|
2022-07-20 08:28:22 +02:00
|
|
|
detect_darwin_sdk_path("macos", env)
|
2020-03-30 08:28:32 +02:00
|
|
|
env.Append(CCFLAGS=["-isysroot", "$MACOS_SDK_PATH"])
|
|
|
|
env.Append(LINKFLAGS=["-isysroot", "$MACOS_SDK_PATH"])
|
2018-08-24 02:03:57 +02:00
|
|
|
|
2020-03-30 08:28:32 +02:00
|
|
|
else: # osxcross build
|
2022-08-29 11:01:15 +02:00
|
|
|
root = os.environ.get("OSXCROSS_ROOT", "")
|
2020-07-20 20:30:40 +02:00
|
|
|
if env["arch"] == "arm64":
|
|
|
|
basecmd = root + "/target/bin/arm64-apple-" + env["osxcross_sdk"] + "-"
|
|
|
|
else:
|
|
|
|
basecmd = root + "/target/bin/x86_64-apple-" + env["osxcross_sdk"] + "-"
|
2015-09-04 04:24:55 +02:00
|
|
|
|
2017-11-10 01:07:28 +01:00
|
|
|
ccache_path = os.environ.get("CCACHE")
|
2018-10-27 01:18:15 +02:00
|
|
|
if ccache_path is None:
|
2020-03-30 08:28:32 +02:00
|
|
|
env["CC"] = basecmd + "cc"
|
|
|
|
env["CXX"] = basecmd + "c++"
|
2017-11-10 01:07:28 +01:00
|
|
|
else:
|
2023-03-12 17:48:52 +01:00
|
|
|
# there aren't any ccache wrappers available for macOS cross-compile,
|
2017-11-10 01:07:28 +01:00
|
|
|
# to enable caching we need to prepend the path to the ccache binary
|
2020-03-30 08:28:32 +02:00
|
|
|
env["CC"] = ccache_path + " " + basecmd + "cc"
|
|
|
|
env["CXX"] = ccache_path + " " + basecmd + "c++"
|
|
|
|
env["AR"] = basecmd + "ar"
|
|
|
|
env["RANLIB"] = basecmd + "ranlib"
|
|
|
|
env["AS"] = basecmd + "as"
|
|
|
|
|
2022-07-21 15:15:54 +02:00
|
|
|
# LTO
|
2022-09-13 17:01:47 +02:00
|
|
|
|
|
|
|
if env["lto"] == "auto": # LTO benefits for macOS (size, performance) haven't been clearly established yet.
|
|
|
|
env["lto"] = "none"
|
|
|
|
|
2022-07-21 15:15:54 +02:00
|
|
|
if env["lto"] != "none":
|
|
|
|
if env["lto"] == "thin":
|
|
|
|
env.Append(CCFLAGS=["-flto=thin"])
|
|
|
|
env.Append(LINKFLAGS=["-flto=thin"])
|
|
|
|
else:
|
|
|
|
env.Append(CCFLAGS=["-flto"])
|
|
|
|
env.Append(LINKFLAGS=["-flto"])
|
|
|
|
|
2022-09-13 17:01:47 +02:00
|
|
|
# Sanitizers
|
|
|
|
|
2021-04-15 23:08:02 +02:00
|
|
|
if env["use_ubsan"] or env["use_asan"] or env["use_tsan"]:
|
2021-12-10 17:10:47 +01:00
|
|
|
env.extra_suffix += ".san"
|
2022-04-01 12:15:35 +02:00
|
|
|
env.Append(CCFLAGS=["-DSANITIZERS_ENABLED"])
|
2020-01-29 06:12:38 +01:00
|
|
|
|
2020-03-30 08:28:32 +02:00
|
|
|
if env["use_ubsan"]:
|
2020-08-01 08:35:37 +02:00
|
|
|
env.Append(
|
|
|
|
CCFLAGS=[
|
|
|
|
"-fsanitize=undefined,shift,shift-exponent,integer-divide-by-zero,unreachable,vla-bound,null,return,signed-integer-overflow,bounds,float-divide-by-zero,float-cast-overflow,nonnull-attribute,returns-nonnull-attribute,bool,enum,vptr,pointer-overflow,builtin"
|
|
|
|
]
|
|
|
|
)
|
2020-03-30 08:28:32 +02:00
|
|
|
env.Append(LINKFLAGS=["-fsanitize=undefined"])
|
2021-04-15 23:08:02 +02:00
|
|
|
env.Append(CCFLAGS=["-fsanitize=nullability-return,nullability-arg,function,nullability-assign"])
|
2020-01-29 06:12:38 +01:00
|
|
|
|
2020-03-30 08:28:32 +02:00
|
|
|
if env["use_asan"]:
|
2020-08-01 08:35:37 +02:00
|
|
|
env.Append(CCFLAGS=["-fsanitize=address,pointer-subtract,pointer-compare"])
|
2020-03-30 08:28:32 +02:00
|
|
|
env.Append(LINKFLAGS=["-fsanitize=address"])
|
2020-01-29 06:12:38 +01:00
|
|
|
|
2020-03-30 08:28:32 +02:00
|
|
|
if env["use_tsan"]:
|
|
|
|
env.Append(CCFLAGS=["-fsanitize=thread"])
|
|
|
|
env.Append(LINKFLAGS=["-fsanitize=thread"])
|
2020-01-29 06:12:38 +01:00
|
|
|
|
2021-10-29 00:00:19 +02:00
|
|
|
if env["use_coverage"]:
|
|
|
|
env.Append(CCFLAGS=["-ftest-coverage", "-fprofile-arcs"])
|
|
|
|
env.Append(LINKFLAGS=["-ftest-coverage", "-fprofile-arcs"])
|
|
|
|
|
2017-06-30 19:21:38 +02:00
|
|
|
## Dependencies
|
|
|
|
|
2021-12-16 02:38:10 +01:00
|
|
|
if env["builtin_libtheora"] and env["arch"] == "x86_64":
|
|
|
|
env["x86_libtheora_opt_gcc"] = True
|
2017-06-30 19:21:38 +02:00
|
|
|
|
|
|
|
## Flags
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2022-07-20 08:28:22 +02:00
|
|
|
env.Prepend(CPPPATH=["#platform/macos"])
|
2022-09-02 11:37:48 +02:00
|
|
|
env.Append(CPPDEFINES=["MACOS_ENABLED", "UNIX_ENABLED", "COREAUDIO_ENABLED", "COREMIDI_ENABLED"])
|
2020-03-30 08:28:32 +02:00
|
|
|
env.Append(
|
|
|
|
LINKFLAGS=[
|
|
|
|
"-framework",
|
|
|
|
"Cocoa",
|
|
|
|
"-framework",
|
|
|
|
"Carbon",
|
|
|
|
"-framework",
|
|
|
|
"AudioUnit",
|
|
|
|
"-framework",
|
|
|
|
"CoreAudio",
|
|
|
|
"-framework",
|
|
|
|
"CoreMIDI",
|
|
|
|
"-framework",
|
|
|
|
"IOKit",
|
|
|
|
"-framework",
|
|
|
|
"ForceFeedback",
|
|
|
|
"-framework",
|
|
|
|
"CoreVideo",
|
|
|
|
"-framework",
|
|
|
|
"AVFoundation",
|
|
|
|
"-framework",
|
|
|
|
"CoreMedia",
|
2022-10-25 21:20:54 +02:00
|
|
|
"-framework",
|
|
|
|
"QuartzCore",
|
2023-04-13 21:17:55 +02:00
|
|
|
"-framework",
|
|
|
|
"Security",
|
2020-03-30 08:28:32 +02:00
|
|
|
]
|
|
|
|
)
|
|
|
|
env.Append(LIBS=["pthread", "z"])
|
|
|
|
|
2021-11-02 11:27:38 +01:00
|
|
|
if env["opengl3"]:
|
2023-01-20 23:20:30 +01:00
|
|
|
env.Append(CPPDEFINES=["GLES3_ENABLED"])
|
2021-11-12 13:49:49 +01:00
|
|
|
if env["angle_libs"] != "":
|
|
|
|
env.AppendUnique(CPPDEFINES=["EGL_STATIC"])
|
|
|
|
env.Append(LINKFLAGS=["-L" + env["angle_libs"]])
|
|
|
|
env.Append(LINKFLAGS=["-lANGLE.macos." + env["arch"]])
|
|
|
|
env.Append(LINKFLAGS=["-lEGL.macos." + env["arch"]])
|
|
|
|
env.Append(LINKFLAGS=["-lGLES.macos." + env["arch"]])
|
|
|
|
env.Prepend(CPPPATH=["#thirdparty/angle/include"])
|
2021-11-02 11:27:38 +01:00
|
|
|
|
2022-01-26 10:01:27 +01:00
|
|
|
env.Append(LINKFLAGS=["-rpath", "@executable_path/../Frameworks", "-rpath", "@executable_path"])
|
|
|
|
|
2021-08-12 13:24:54 +02:00
|
|
|
if env["vulkan"]:
|
2023-12-22 13:49:29 +01:00
|
|
|
env.Append(CPPDEFINES=["VULKAN_ENABLED", "RD_ENABLED"])
|
2022-10-25 21:20:54 +02:00
|
|
|
env.Append(LINKFLAGS=["-framework", "Metal", "-framework", "IOSurface"])
|
2021-08-12 13:24:54 +02:00
|
|
|
if not env["use_volk"]:
|
2022-07-03 14:58:07 +02:00
|
|
|
env.Append(LINKFLAGS=["-lMoltenVK"])
|
2023-12-11 19:50:44 +01:00
|
|
|
mvk_path = detect_mvk(env, "macos-arm64_x86_64")
|
2022-11-15 10:38:26 +01:00
|
|
|
|
2023-12-11 19:50:44 +01:00
|
|
|
if mvk_path != "":
|
|
|
|
env.Append(LINKFLAGS=["-L" + os.path.join(mvk_path, "macos-arm64_x86_64")])
|
|
|
|
else:
|
2022-07-03 14:58:07 +02:00
|
|
|
print(
|
|
|
|
"MoltenVK SDK installation directory not found, use 'vulkan_sdk_path' SCons parameter to specify SDK path."
|
|
|
|
)
|
|
|
|
sys.exit(255)
|