3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-10-26 17:29:21 +00:00

Move `mk_def_file_internal() out of mk_util.py` into

``mk_genfile_common.py`` and adapt ``mk_util.py`` and
``mk_def_file.py`` to use the code at its new location.

Whilst I'm here also reindent ``mk_def_file.py`` and make it
use some of the code in ``mk_genfile_common.py`` to avoid code
duplication.

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.
This commit is contained in:
Dan Liew 2016-03-08 19:08:47 +00:00
parent 2b64729b21
commit 8a35f744c7
3 changed files with 51 additions and 39 deletions

View file

@ -6,31 +6,31 @@ exported symbols of a dll. This file
can be passed to the ``/DEF`` to the can be passed to the ``/DEF`` to the
linker used by MSVC. linker used by MSVC.
""" """
import mk_util import mk_genfile_common
import argparse import argparse
import logging import logging
import os import os
import sys import sys
def main(args): def main(args):
logging.basicConfig(level=logging.INFO) logging.basicConfig(level=logging.INFO)
parser = argparse.ArgumentParser(description=__doc__) parser = argparse.ArgumentParser(description=__doc__)
parser.add_argument("output_file", help="output def file path") parser.add_argument("output_file", help="output def file path")
parser.add_argument("dllname", help="dllname to use in def file") parser.add_argument("dllname", help="dllname to use in def file")
parser.add_argument("api_files", nargs="+") parser.add_argument("api_files", nargs="+")
pargs = parser.parse_args(args) pargs = parser.parse_args(args)
for api_file in pargs.api_files: if not mk_genfile_common.check_files_exist(pargs.api_files):
if not os.path.exists(api_file): logging.error('One or more api files do not exist')
logging.error('"{}" does not exist'.format(api_file)) return 1
return 1
mk_util.mk_def_file_internal( mk_genfile_common.mk_def_file_internal(
pargs.output_file, pargs.output_file,
pargs.dllname, pargs.dllname,
pargs.api_files) pargs.api_files)
return 0 logging.info('Generated "{}"'.format(pargs.output_file))
return 0
if __name__ == '__main__': if __name__ == '__main__':
sys.exit(main(sys.argv[1:])) sys.exit(main(sys.argv[1:]))

View file

@ -124,3 +124,36 @@ def mk_z3consts_py_internal(api_files, output_dir):
api.close() api.close()
z3consts.close() z3consts.close()
return z3consts_output_path return z3consts_output_path
###############################################################################
# Functions for generating a "module definition file" for MSVC
###############################################################################
def mk_def_file_internal(defname, dll_name, export_header_files):
"""
Writes to a module definition file to a file named ``defname``.
``dll_name`` is the name of the dll (without the ``.dll`` suffix).
``export_header_file`` is a list of header files to scan for symbols
to include in the module definition file.
"""
assert isinstance(export_header_files, list)
pat1 = re.compile(".*Z3_API.*")
fout = open(defname, 'w')
fout.write('LIBRARY "%s"\nEXPORTS\n' % dll_name)
num = 1
for export_header_file in export_header_files:
api = open(export_header_file, 'r')
for line in api:
m = pat1.match(line)
if m:
words = re.split('\W+', line)
i = 0
for w in words:
if w == 'Z3_API':
f = words[i+1]
fout.write('\t%s @%s\n' % (f, num))
i = i + 1
num = num + 1
api.close()
fout.close()

View file

@ -2913,28 +2913,7 @@ def mk_def_file(c):
dot_h_c = c.find_file(dot_h, c.name) dot_h_c = c.find_file(dot_h, c.name)
api = os.path.join(dot_h_c.src_dir, dot_h) api = os.path.join(dot_h_c.src_dir, dot_h)
export_header_files.append(api) export_header_files.append(api)
mk_def_file_internal(defname, dll_name, export_header_files) mk_genfile_common.mk_def_file_internal(defname, dll_name, export_header_files)
def mk_def_file_internal(defname, dll_name, export_header_files):
pat1 = re.compile(".*Z3_API.*")
fout = open(defname, 'w')
fout.write('LIBRARY "%s"\nEXPORTS\n' % dll_name)
num = 1
for export_header_file in export_header_files:
api = open(export_header_file, 'r')
for line in api:
m = pat1.match(line)
if m:
words = re.split('\W+', line)
i = 0
for w in words:
if w == 'Z3_API':
f = words[i+1]
fout.write('\t%s @%s\n' % (f, num))
i = i + 1
num = num + 1
api.close()
fout.close()
if VERBOSE: if VERBOSE:
print("Generated '%s'" % defname) print("Generated '%s'" % defname)