mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-28 18:40:29 +00:00
9812fac2c3
These headers are platform-specific, and shouldn't need to be used by Swift code anyway.
73 lines
2.5 KiB
Python
73 lines
2.5 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
Generates a clang module map for a given directory
|
|
"""
|
|
|
|
import argparse
|
|
import pathlib
|
|
import yaml
|
|
import sys
|
|
|
|
|
|
def write_file_if_not_same(file_path, content):
|
|
try:
|
|
with open(file_path, 'r') as f:
|
|
if f.read() == content:
|
|
return
|
|
except FileNotFoundError:
|
|
pass
|
|
|
|
with open(file_path, 'w') as f:
|
|
f.write(content)
|
|
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser(
|
|
epilog=__doc__,
|
|
formatter_class=argparse.RawDescriptionHelpFormatter)
|
|
parser.add_argument('directory', help='source directory to generate module map for')
|
|
parser.add_argument('--module-name', help='top-level module name')
|
|
parser.add_argument('--module-map', required=True, help='output module map file')
|
|
parser.add_argument('--vfs-map', required=True, help='output VFS map file')
|
|
parser.add_argument('--exclude-files', nargs='*', required=False, help='files to exclude in the module map')
|
|
parser.add_argument('--generated-files', nargs='*', help='extra files to include in the module map')
|
|
args = parser.parse_args()
|
|
|
|
root = pathlib.Path(args.directory)
|
|
if not root.is_dir():
|
|
print(f"Error: {args.directory} is not a directory", file=sys.stderr)
|
|
return 1
|
|
pathlib.Path(args.module_map).parent.mkdir(parents=True, exist_ok=True)
|
|
pathlib.Path(args.vfs_map).parent.mkdir(parents=True, exist_ok=True)
|
|
exclude_files = set(args.exclude_files) if args.exclude_files else set()
|
|
|
|
header_files = [f for f in root.rglob('**/*.h') if f.is_file() and f.name not in exclude_files]
|
|
module_name = args.module_name if args.module_name else root.name
|
|
|
|
module_map = f"module {module_name} {{\n"
|
|
for header_file in header_files:
|
|
module_map += f" header \"{header_file.relative_to(root)}\"\n"
|
|
for generated_file in args.generated_files:
|
|
module_map += f" header \"{generated_file}\"\n"
|
|
module_map += " requires cplusplus\n"
|
|
module_map += " export *\n"
|
|
module_map += "}\n"
|
|
|
|
vfs_map = {
|
|
"version": 0,
|
|
"use-external-names": False,
|
|
"roots": [
|
|
{
|
|
"name": f"{root}/module.modulemap",
|
|
"type": "file",
|
|
"external-contents": f"{args.module_map}"
|
|
}
|
|
]
|
|
}
|
|
|
|
write_file_if_not_same(args.module_map, module_map)
|
|
write_file_if_not_same(args.vfs_map, yaml.dump(vfs_map))
|
|
|
|
|
|
if __name__ == '__main__':
|
|
sys.exit(main())
|