summaryrefslogtreecommitdiffstats
path: root/tools/godotcpp.py
diff options
context:
space:
mode:
authorFabio Alessandrelli <fabio.alessandrelli@gmail.com>2024-01-30 09:32:27 +0100
committerFabio Alessandrelli <fabio.alessandrelli@gmail.com>2024-02-14 21:20:38 +0100
commitbaaad7ada247bae37b68b5e42de7f7815a457535 (patch)
treed84ed4bb4d94c85dbd93364bbfa4945fffdecae6 /tools/godotcpp.py
parent5fcc43e54d68c45e7875a189e476c5fe7e14237d (diff)
downloadredot-cpp-baaad7ada247bae37b68b5e42de7f7815a457535.tar.gz
[SCons] Add support for custom build tools and platforms
Use with: `scons platform=os2 custom_tools=/path/to/tools` (assuming you have an `os2.py` inside `/path/to/tools/`)
Diffstat (limited to 'tools/godotcpp.py')
-rw-r--r--tools/godotcpp.py44
1 files changed, 38 insertions, 6 deletions
diff --git a/tools/godotcpp.py b/tools/godotcpp.py
index 0b02eea..b5bf37c 100644
--- a/tools/godotcpp.py
+++ b/tools/godotcpp.py
@@ -33,7 +33,26 @@ def validate_parent_dir(key, val, env):
raise UserError("'%s' is not a directory: %s" % (key, os.path.dirname(val)))
-platforms = ("linux", "macos", "windows", "android", "ios", "web")
+def get_platform_tools_paths(env):
+ path = env.get("custom_tools", None)
+ if path is None:
+ return ["tools"]
+ return [normalize_path(path, env), "tools"]
+
+
+def get_custom_platforms(env):
+ path = env.get("custom_tools", None)
+ if path is None:
+ return []
+ platforms = []
+ for x in os.listdir(normalize_path(path, env)):
+ if not x.endswith(".py"):
+ continue
+ platforms.append(x.removesuffix(".py"))
+ return platforms
+
+
+platforms = ["linux", "macos", "windows", "android", "ios", "web"]
# CPU architecture options.
architecture_array = [
@@ -83,11 +102,24 @@ def options(opts, env):
raise ValueError("Could not detect platform automatically, please specify with platform=<platform>")
opts.Add(
+ PathVariable(
+ key="custom_tools",
+ help="Path to directory containing custom tools",
+ default=env.get("custom_tools", None),
+ validator=validate_dir,
+ )
+ )
+
+ opts.Update(env)
+
+ custom_platforms = get_custom_platforms(env)
+
+ opts.Add(
EnumVariable(
key="platform",
help="Target platform",
default=env.get("platform", default_platform),
- allowed_values=platforms,
+ allowed_values=platforms + custom_platforms,
ignorecase=2,
)
)
@@ -198,9 +230,9 @@ def options(opts, env):
)
)
- # Add platform options
- for pl in platforms:
- tool = Tool(pl, toolpath=["tools"])
+ # Add platform options (custom tools can override platforms)
+ for pl in sorted(set(platforms + custom_platforms)):
+ tool = Tool(pl, toolpath=get_platform_tools_paths(env))
if hasattr(tool, "options"):
tool.options(opts)
@@ -259,7 +291,7 @@ def generate(env):
if env["use_hot_reload"]:
env.Append(CPPDEFINES=["HOT_RELOAD_ENABLED"])
- tool = Tool(env["platform"], toolpath=["tools"])
+ tool = Tool(env["platform"], toolpath=get_platform_tools_paths(env))
if tool is None or not tool.exists(env):
raise ValueError("Required toolchain not found for platform " + env["platform"])