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