[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/`)

(cherry picked from commit baaad7ada2)
pull/1411/head
Fabio Alessandrelli 2024-01-30 09:32:27 +01:00 committed by David Snopek
parent 1ac8627b2e
commit bab62a4d72
1 changed files with 38 additions and 6 deletions

View File

@ -33,7 +33,26 @@ def validate_parent_dir(key, val, env):
raise UserError("'%s' is not a directory: %s" % (key, os.path.dirname(val))) 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. # CPU architecture options.
architecture_array = [ architecture_array = [
@ -82,12 +101,25 @@ def options(opts, env):
else: else:
raise ValueError("Could not detect platform automatically, please specify with platform=<platform>") 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( opts.Add(
EnumVariable( EnumVariable(
key="platform", key="platform",
help="Target platform", help="Target platform",
default=env.get("platform", default_platform), default=env.get("platform", default_platform),
allowed_values=platforms, allowed_values=platforms + custom_platforms,
ignorecase=2, ignorecase=2,
) )
) )
@ -183,9 +215,9 @@ def options(opts, env):
) )
) )
# Add platform options # Add platform options (custom tools can override platforms)
for pl in platforms: for pl in sorted(set(platforms + custom_platforms)):
tool = Tool(pl, toolpath=["tools"]) tool = Tool(pl, toolpath=get_platform_tools_paths(env))
if hasattr(tool, "options"): if hasattr(tool, "options"):
tool.options(opts) tool.options(opts)
@ -239,7 +271,7 @@ def generate(env):
print("Building for architecture " + env["arch"] + " on platform " + env["platform"]) print("Building for architecture " + env["arch"] + " on platform " + env["platform"])
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): if tool is None or not tool.exists(env):
raise ValueError("Required toolchain not found for platform " + env["platform"]) raise ValueError("Required toolchain not found for platform " + env["platform"])