You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

86 lines
2.8 KiB

#!/usr/bin/env python3
#
# Copyright (C) 2020 The Android Open Source Project
#
# 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
#
# http://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.
#
"""Generates the NDK API docs for local viewing.
Note that the local docs will not exactly match the docs that are uploaded to
devsite. The theming is different and the per-file view is not available.
Ensure that your documentation is accessible from the module view or it will
not be discoverable on devsite.
"""
import argparse
import os
from pathlib import Path
import shutil
import subprocess
import sys
THIS_DIR = Path(__file__).resolve().parent
ANDROID_TOP = THIS_DIR.parents[2]
def check_environment() -> None:
"""Validates that we have everything we need from the environment."""
if shutil.which('doxygen') is None:
sys.exit('Doxygen not found. Run `sudo apt install doxygen`.')
if 'ANDROID_PRODUCT_OUT' not in os.environ:
sys.exit('Could not find ANDROID_PRODUCT_OUT. Run lunch.')
def build_ndk() -> None:
"""Builds the NDK sysroot."""
subprocess.run(["build/soong/soong_ui.bash", "--make-mode", "ndk"],
cwd=ANDROID_TOP,
check=True)
def generate_docs() -> None:
"""Generates the NDK API reference."""
product_out = Path(os.environ['ANDROID_PRODUCT_OUT'])
out_dir = product_out.parents[1] / 'common/ndk-docs'
html_dir = out_dir / 'html'
input_dir = product_out.parents[2] / 'soong/ndk/sysroot/usr/include'
doxyfile_template = ANDROID_TOP / 'frameworks/native/docs/Doxyfile'
out_dir.mkdir(parents=True, exist_ok=True)
doxyfile = out_dir / 'Doxyfile'
doxyfile_contents = doxyfile_template.read_text()
doxyfile_contents += f'\nINPUT={input_dir}\nHTML_OUTPUT={html_dir}'
doxyfile.write_text(doxyfile_contents)
subprocess.run(['doxygen', str(doxyfile)], cwd=ANDROID_TOP, check=True)
index = html_dir / 'index.html'
print(f'Generated NDK API documentation to {index.as_uri()}')
def parse_args() -> argparse.Namespace:
"""Parses command line arguments."""
parser = argparse.ArgumentParser(description=sys.modules[__name__].__doc__)
return parser.parse_args()
def main() -> None:
"""Program entry point."""
_ = parse_args()
check_environment()
build_ndk()
generate_docs()
if __name__ == '__main__':
main()