aboutsummaryrefslogtreecommitdiff
path: root/docs/run_doxygen.py
diff options
context:
space:
mode:
Diffstat (limited to 'docs/run_doxygen.py')
-rw-r--r--docs/run_doxygen.py95
1 files changed, 95 insertions, 0 deletions
diff --git a/docs/run_doxygen.py b/docs/run_doxygen.py
new file mode 100644
index 000000000..b0b921838
--- /dev/null
+++ b/docs/run_doxygen.py
@@ -0,0 +1,95 @@
+# 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()))