SCons: Improve logic to generate modules_tests.gen.h
This removes the need for `AlwaysBuild` by ensuring that the proper files are being tracked as `Depends`.
This commit is contained in:
parent
f425d403fe
commit
3495288b03
2 changed files with 30 additions and 24 deletions
|
@ -22,12 +22,37 @@ env.CommandNoCache(
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
# Header to be included in `tests/test_main.cpp` to run module-specific tests.
|
|
||||||
|
vs_sources = []
|
||||||
|
test_headers = []
|
||||||
|
# libmodule_<name>.a for each active module.
|
||||||
|
for name, path in env.module_list.items():
|
||||||
|
env.modules_sources = []
|
||||||
|
|
||||||
|
# Name for built-in modules, (absolute) path for custom ones.
|
||||||
|
base_path = path if os.path.isabs(path) else name
|
||||||
|
SConscript(base_path + "/SCsub")
|
||||||
|
|
||||||
|
lib = env_modules.add_library("module_%s" % name, env.modules_sources)
|
||||||
|
env.Prepend(LIBS=[lib])
|
||||||
|
if env["vsproj"]:
|
||||||
|
vs_sources += env.modules_sources
|
||||||
|
|
||||||
|
if env["tests"]:
|
||||||
|
# Lookup potential headers in `tests` subfolder.
|
||||||
|
import glob
|
||||||
|
|
||||||
|
module_tests = sorted(glob.glob(os.path.join(base_path, "tests", "*.h")))
|
||||||
|
if module_tests != []:
|
||||||
|
test_headers += module_tests
|
||||||
|
|
||||||
|
|
||||||
|
# Generate header to be included in `tests/test_main.cpp` to run module-specific tests.
|
||||||
if env["tests"]:
|
if env["tests"]:
|
||||||
env.Depends("modules_tests.gen.h", Value(env.module_list))
|
env.Depends("modules_tests.gen.h", test_headers)
|
||||||
env.CommandNoCache(
|
env.CommandNoCache(
|
||||||
"modules_tests.gen.h",
|
"modules_tests.gen.h",
|
||||||
Value(env.module_list),
|
test_headers,
|
||||||
env.Run(
|
env.Run(
|
||||||
modules_builders.generate_modules_tests,
|
modules_builders.generate_modules_tests,
|
||||||
"Generating modules tests header.",
|
"Generating modules tests header.",
|
||||||
|
@ -35,22 +60,6 @@ if env["tests"]:
|
||||||
subprocess=False,
|
subprocess=False,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
env.AlwaysBuild("modules_tests.gen.h")
|
|
||||||
|
|
||||||
vs_sources = []
|
|
||||||
# libmodule_<name>.a for each active module.
|
|
||||||
for name, path in env.module_list.items():
|
|
||||||
env.modules_sources = []
|
|
||||||
|
|
||||||
if not os.path.isabs(path):
|
|
||||||
SConscript(name + "/SCsub") # Built-in.
|
|
||||||
else:
|
|
||||||
SConscript(path + "/SCsub") # Custom.
|
|
||||||
|
|
||||||
lib = env_modules.add_library("module_%s" % name, env.modules_sources)
|
|
||||||
env.Prepend(LIBS=[lib])
|
|
||||||
if env["vsproj"]:
|
|
||||||
vs_sources += env.modules_sources
|
|
||||||
|
|
||||||
# libmodules.a with only register_module_types.
|
# libmodules.a with only register_module_types.
|
||||||
# Must be last so that all libmodule_<name>.a libraries are on the right side
|
# Must be last so that all libmodule_<name>.a libraries are on the right side
|
||||||
|
|
|
@ -14,13 +14,10 @@ def generate_modules_enabled(target, source, env):
|
||||||
|
|
||||||
def generate_modules_tests(target, source, env):
|
def generate_modules_tests(target, source, env):
|
||||||
import os
|
import os
|
||||||
import glob
|
|
||||||
|
|
||||||
with open(target[0].path, "w") as f:
|
with open(target[0].path, "w") as f:
|
||||||
for name, path in env.module_list.items():
|
for header in source:
|
||||||
headers = glob.glob(os.path.join(path, "tests", "*.h"))
|
f.write('#include "%s"\n' % (os.path.normpath(header.path)))
|
||||||
for h in headers:
|
|
||||||
f.write('#include "%s"\n' % (os.path.normpath(h)))
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|
Loading…
Reference in a new issue