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:
Rémi Verschelde 2022-02-08 12:39:40 +01:00
parent f425d403fe
commit 3495288b03
No known key found for this signature in database
GPG key ID: C3336907360768E1
2 changed files with 30 additions and 24 deletions

View file

@ -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

View file

@ -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__":