1#!/usr/bin/env python3 2# 3# Copyright (C) 2020 The Android Open Source Project 4# 5# Licensed under the Apache License, Version 2.0 (the "License"); 6# you may not use this file except in compliance with the License. 7# You may obtain a copy of the License at 8# 9# http://www.apache.org/licenses/LICENSE-2.0 10# 11# Unless required by applicable law or agreed to in writing, software 12# distributed under the License is distributed on an "AS IS" BASIS, 13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14# See the License for the specific language governing permissions and 15# limitations under the License. 16# 17"""Generates the NDK API docs for local viewing. 18 19Note that the local docs will not exactly match the docs that are uploaded to 20devsite. The theming is different and the per-file view is not available. 21Ensure that your documentation is accessible from the module view or it will 22not be discoverable on devsite. 23""" 24import argparse 25import os 26from pathlib import Path 27import shutil 28import subprocess 29import sys 30 31THIS_DIR = Path(__file__).resolve().parent 32ANDROID_TOP = THIS_DIR.parents[2] 33 34 35def check_environment() -> None: 36 """Validates that we have everything we need from the environment.""" 37 if shutil.which('doxygen') is None: 38 sys.exit('Doxygen not found. Run `sudo apt install doxygen`.') 39 40 if 'ANDROID_PRODUCT_OUT' not in os.environ: 41 sys.exit('Could not find ANDROID_PRODUCT_OUT. Run lunch.') 42 43 44def build_ndk() -> None: 45 """Builds the NDK sysroot.""" 46 subprocess.run(["build/soong/soong_ui.bash", "--make-mode", "ndk"], 47 cwd=ANDROID_TOP, 48 check=True) 49 50 51def generate_docs() -> None: 52 """Generates the NDK API reference.""" 53 product_out = Path(os.environ['ANDROID_PRODUCT_OUT']) 54 out_dir = product_out.parents[1] / 'common/ndk-docs' 55 html_dir = out_dir / 'html' 56 input_dir = product_out.parents[2] / 'soong/ndk/sysroot/usr/include' 57 doxyfile_template = ANDROID_TOP / 'frameworks/native/docs/Doxyfile' 58 doxyfile = out_dir / 'Doxyfile' 59 60 doxyfile_contents = doxyfile_template.read_text() 61 doxyfile_contents += f'\nINPUT={input_dir}\nHTML_OUTPUT={html_dir}' 62 doxyfile.write_text(doxyfile_contents) 63 64 subprocess.run(['doxygen', str(doxyfile)], cwd=ANDROID_TOP, check=True) 65 index = html_dir / 'index.html' 66 print(f'Generated NDK API documentation to {index.as_uri()}') 67 68 69def parse_args() -> argparse.Namespace: 70 """Parses command line arguments.""" 71 parser = argparse.ArgumentParser(description=sys.modules[__name__].__doc__) 72 return parser.parse_args() 73 74 75def main() -> None: 76 """Program entry point.""" 77 _ = parse_args() 78 check_environment() 79 build_ndk() 80 generate_docs() 81 82 83if __name__ == '__main__': 84 main() 85