15f9996aaSopenharmony_ci#!/usr/bin/env python 25f9996aaSopenharmony_ci# -*- coding: utf-8 -*- 35f9996aaSopenharmony_ci 45f9996aaSopenharmony_ci# 55f9996aaSopenharmony_ci# Copyright (c) 2020 Huawei Device Co., Ltd. 65f9996aaSopenharmony_ci# Licensed under the Apache License, Version 2.0 (the "License"); 75f9996aaSopenharmony_ci# you may not use this file except in compliance with the License. 85f9996aaSopenharmony_ci# You may obtain a copy of the License at 95f9996aaSopenharmony_ci# 105f9996aaSopenharmony_ci# http://www.apache.org/licenses/LICENSE-2.0 115f9996aaSopenharmony_ci# 125f9996aaSopenharmony_ci# Unless required by applicable law or agreed to in writing, software 135f9996aaSopenharmony_ci# distributed under the License is distributed on an "AS IS" BASIS, 145f9996aaSopenharmony_ci# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 155f9996aaSopenharmony_ci# See the License for the specific language governing permissions and 165f9996aaSopenharmony_ci# limitations under the License. 175f9996aaSopenharmony_ci# 185f9996aaSopenharmony_ci 195f9996aaSopenharmony_ciimport os 205f9996aaSopenharmony_ciimport sys 215f9996aaSopenharmony_ciimport shutil 225f9996aaSopenharmony_ciimport stat 235f9996aaSopenharmony_ciimport re 245f9996aaSopenharmony_ciimport tempfile 255f9996aaSopenharmony_ciimport argparse 265f9996aaSopenharmony_ciimport distutils.spawn 275f9996aaSopenharmony_cisys.path.append(os.path.join(os.path.dirname(__file__), os.pardir, os.pardir)) 285f9996aaSopenharmony_cifrom utils import check_output, makedirs # noqa: E402 295f9996aaSopenharmony_ci 305f9996aaSopenharmony_ci 315f9996aaSopenharmony_cidef gen_doc(args): 325f9996aaSopenharmony_ci html_output_dir = args.output 335f9996aaSopenharmony_ci contents = None 345f9996aaSopenharmony_ci with tempfile.NamedTemporaryFile( 355f9996aaSopenharmony_ci suffix=os.path.basename(args.doxygen_file)) as doxygen_file: 365f9996aaSopenharmony_ci shutil.copyfile(args.doxygen_file, doxygen_file.name) 375f9996aaSopenharmony_ci with open(doxygen_file.name, 'r') as file: 385f9996aaSopenharmony_ci contents = file.read() 395f9996aaSopenharmony_ci if contents is None: 405f9996aaSopenharmony_ci raise Exception('Failed to read %s' % args.doxygen_file) 415f9996aaSopenharmony_ci 425f9996aaSopenharmony_ci keys = { 435f9996aaSopenharmony_ci '%VERSION%': 445f9996aaSopenharmony_ci args.version, 455f9996aaSopenharmony_ci '%EXCLUDE_DIR%': 465f9996aaSopenharmony_ci args.exclude_dir, 475f9996aaSopenharmony_ci '%OUTPUT_DIR%': 485f9996aaSopenharmony_ci os.path.relpath(html_output_dir, args.working_dir) 495f9996aaSopenharmony_ci } 505f9996aaSopenharmony_ci for (key, value) in list(keys.items()): 515f9996aaSopenharmony_ci value = value.replace('\\', '\\\\') 525f9996aaSopenharmony_ci contents = re.sub(key, value, contents) 535f9996aaSopenharmony_ci 545f9996aaSopenharmony_ci with os.fdopen(os.open(doxygen_file.name, 555f9996aaSopenharmony_ci os.O_RDWR | os.O_CREAT, stat.S_IWUSR | stat.S_IRUSR), 565f9996aaSopenharmony_ci 'w', encoding='utf-8') as file: 575f9996aaSopenharmony_ci file.write(contents) 585f9996aaSopenharmony_ci 595f9996aaSopenharmony_ci old_cwd = os.getcwd() 605f9996aaSopenharmony_ci try: 615f9996aaSopenharmony_ci # if no ndk headers exist, return. 625f9996aaSopenharmony_ci if os.path.exists(args.working_dir) is not True: 635f9996aaSopenharmony_ci print("no ndk headers exist, return") 645f9996aaSopenharmony_ci return 655f9996aaSopenharmony_ci os.chdir(args.working_dir) 665f9996aaSopenharmony_ci 675f9996aaSopenharmony_ci doxygen_path = distutils.spawn.find_executable('doxygen') 685f9996aaSopenharmony_ci if doxygen_path is None: 695f9996aaSopenharmony_ci print( 705f9996aaSopenharmony_ci "Warning: Failed to find doxygen, please install doxygen " 715f9996aaSopenharmony_ci "with \"sudo apt-get install doxygen\" on Ubuntu" 725f9996aaSopenharmony_ci ) 735f9996aaSopenharmony_ci return 745f9996aaSopenharmony_ci html_output_dir = os.path.relpath(html_output_dir, 755f9996aaSopenharmony_ci args.working_dir) 765f9996aaSopenharmony_ci if not os.path.exists(html_output_dir): 775f9996aaSopenharmony_ci makedirs(html_output_dir) 785f9996aaSopenharmony_ci cmd = [doxygen_path, doxygen_file.name] 795f9996aaSopenharmony_ci check_output(cmd) 805f9996aaSopenharmony_ci 815f9996aaSopenharmony_ci finally: 825f9996aaSopenharmony_ci os.chdir(old_cwd) 835f9996aaSopenharmony_ci 845f9996aaSopenharmony_ci 855f9996aaSopenharmony_cidef main(): 865f9996aaSopenharmony_ci parser = argparse.ArgumentParser(description='Generate ndk docs') 875f9996aaSopenharmony_ci parser.add_argument('--version', help='OHOS version', required=True) 885f9996aaSopenharmony_ci parser.add_argument('--exclude_dir', help='doxygen exclude dirs', 895f9996aaSopenharmony_ci required=True) 905f9996aaSopenharmony_ci parser.add_argument('--doxygen-file', help='doxygen config file') 915f9996aaSopenharmony_ci parser.add_argument('--output', help='output index.html') 925f9996aaSopenharmony_ci parser.add_argument( 935f9996aaSopenharmony_ci '--working-dir', 945f9996aaSopenharmony_ci help='the directory where doxygen command will be executed') 955f9996aaSopenharmony_ci args = parser.parse_args() 965f9996aaSopenharmony_ci 975f9996aaSopenharmony_ci return gen_doc(args) 985f9996aaSopenharmony_ci 995f9996aaSopenharmony_ci 1005f9996aaSopenharmony_ciif __name__ == "__main__": 1015f9996aaSopenharmony_ci sys.exit(main()) 102