mirror of
https://github.com/Z3Prover/z3
synced 2025-04-07 09:55:19 +00:00
Previously CMake was not aware of which headers files the generation of `gparams_register_modules.cpp` depended on. Consequently this could result in broken incremental builds if * Existing headers that declared module description/parameters change. * New headers are added that declare module description/parameters. * `.pyg` files that generate header files that declare module description/parameters change Now the `z3_add_component()` CMake function has been modifed so that * All header files that are generated from `.pyg` files are added as dependencies and are scanned from module description/parameter declarations. This implicit dependency of `gparams_register_modules.cpp` depending on other generated header files seems unnecessary complex. We should revisit this design decision once the Python/Makefile build system is deprecated. * The function now takes an optional `EXTRA_REGISTER_MODULE_HEADERS` argument which allows the headers that declare module description/paramters to be explicitly listed. With this information CMake will now regenerate `gparams_register_modules.cpp` correctly. This required the `mk_gparams_register_modules_internal()` function to be changed to take a list of header files rather than a list of component source directories. The two consumers (CMake and Python/Makefile build systems) of this function have been modified to work with this change. This partially fixes #1030.
41 lines
1.2 KiB
Python
Executable file
41 lines
1.2 KiB
Python
Executable file
#!/usr/bin/env python
|
|
"""
|
|
Determines the available global parameters from a list of header files and
|
|
generates a ``gparams_register_modules.cpp`` file in the destination directory
|
|
that defines a function ``void gparams_register_modules()``.
|
|
"""
|
|
import mk_genfile_common
|
|
import argparse
|
|
import logging
|
|
import os
|
|
import sys
|
|
|
|
def main(args):
|
|
logging.basicConfig(level=logging.INFO)
|
|
parser = argparse.ArgumentParser(description=__doc__)
|
|
parser.add_argument("destination_dir", help="destination directory")
|
|
parser.add_argument("header_files", nargs="+",
|
|
help="One or more header files to parse")
|
|
pargs = parser.parse_args(args)
|
|
|
|
if not mk_genfile_common.check_dir_exists(pargs.destination_dir):
|
|
return 1
|
|
|
|
if not mk_genfile_common.check_files_exist(pargs.header_files):
|
|
return 1
|
|
|
|
h_files_full_path = []
|
|
for header_file in pargs.header_files:
|
|
h_files_full_path.append(os.path.abspath(header_file))
|
|
|
|
output = mk_genfile_common.mk_gparams_register_modules_internal(
|
|
h_files_full_path,
|
|
pargs.destination_dir
|
|
)
|
|
logging.info('Generated "{}"'.format(output))
|
|
return 0
|
|
|
|
if __name__ == '__main__':
|
|
sys.exit(main(sys.argv[1:]))
|
|
|