mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 17:44:08 +00:00
``mk_genfile_common.py`` and adapt ``mk_util.py`` and ``mk_mem_initializer_cpp.py`` to use the code at its new location. The interface has been changed slightly so that ``mk_mem_initializer_cpp_internal()`` now returns the path the generated file. The motivation behind this is so that clients of the function know the path of the generated file. Whilst I'm here reindent ``mk_mem_initializer_cpp.py`` and the relevant code in ``mk_util.py``. The purpose of this change is to have Python code common to the Python and CMake build systems separate from Python code that is only used for the Python build system.
41 lines
1.1 KiB
Python
Executable file
41 lines
1.1 KiB
Python
Executable file
#!/usr/bin/env python
|
|
"""
|
|
Scans the source directories for
|
|
memory initializers and finalizers and
|
|
emits and implementation of
|
|
``void mem_initialize()`` and
|
|
``void mem_finalize()`` into ``mem_initializer.cpp``
|
|
in the destination directory.
|
|
"""
|
|
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("source_dirs", nargs="+",
|
|
help="One or more source directories to search")
|
|
pargs = parser.parse_args(args)
|
|
|
|
if not mk_genfile_common.check_dir_exists(pargs.destination_dir):
|
|
return 1
|
|
|
|
for source_dir in pargs.source_dirs:
|
|
if not mk_genfile_common.check_dir_exists(source_dir):
|
|
return 1
|
|
|
|
output = mk_genfile_common.mk_mem_initializer_cpp_internal(
|
|
pargs.source_dirs,
|
|
pargs.destination_dir
|
|
)
|
|
logging.info('Generated "{}"'.format(output))
|
|
return 0
|
|
|
|
if __name__ == '__main__':
|
|
sys.exit(main(sys.argv[1:]))
|
|
|