# Copyright 2023 The Pigweed Authors # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy of # the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations under # the License. """Run doxygen on all Pigweed modules.""" import argparse import os from pathlib import Path import shutil import subprocess import sys from typing import List def _parse_args() -> argparse.Namespace: parser = argparse.ArgumentParser(description=__doc__) parser.add_argument( '--gn-root', type=Path, required=True, help='Root of the GN tree.', ) parser.add_argument( '--pigweed-modules-file', type=Path, required=True, help='Pigweed modules list file', ) parser.add_argument( '--output-dir', type=Path, required=True, help='Location to write output to', ) parser.add_argument( '--doxygen-config', type=Path, required=True, help='Location to write output to', ) parser.add_argument( '--include-paths', nargs='+', type=Path, ) return parser.parse_args() def main( gn_root: Path, pigweed_modules_file: Path, output_dir: Path, doxygen_config: Path, include_paths: List[Path], ) -> None: root_build_dir = Path.cwd() # Pigweed top level module list. pw_module_list = [ str((gn_root / path).resolve()) for path in pigweed_modules_file.read_text().splitlines() ] # Use selected modules only if provided if include_paths: pw_module_list = [ str((root_build_dir / path).resolve()) for path in include_paths ] env = os.environ.copy() env['PW_DOXYGEN_OUTPUT_DIRECTORY'] = str(output_dir.resolve()) env['PW_DOXYGEN_INPUT'] = ' '.join(pw_module_list) env['PW_DOXYGEN_PROJECT_NAME'] = 'Pigweed' # Clean out old xmls shutil.rmtree(output_dir, ignore_errors=True) output_dir.mkdir(parents=True, exist_ok=True) command = ['doxygen', str(doxygen_config.resolve())] process = subprocess.run(command, env=env, check=True) sys.exit(process.returncode) if __name__ == '__main__': main(**vars(_parse_args()))