-
Notifications
You must be signed in to change notification settings - Fork 634
/
generate_docs.py
105 lines (92 loc) · 3.69 KB
/
generate_docs.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#!/usr/bin/env python3
import subprocess
import sys
import argparse
import os
import zipfile
# Executes the passed command in a shell subprocess.
# Returns True if any output is received from the shell process.
def run_cmd(cmd):
"""
Execute the input command on the shell.
"""
print(f"Executing command: {cmd}")
try:
result = subprocess.run(
cmd,
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT,
shell=True,
encoding="utf-8",
check=True,
timeout=180,
)
print( result.stdout )
return (len(result.stdout) > 0)
except subprocess.CalledProcessError as e:
result = e.stdout
return result
def get_lib_paths(root):
"""
Get all of the paths, relative to the root, to the libraries under the
standard and aws library folders.
"""
libs_classifications = ["standard", "aws"]
abs_lib_paths = []
for lib in libs_classifications:
libs_path = os.path.join(root, "libraries", lib)
lib_dirs = os.listdir(libs_path)
abs_lib_paths += list(map(lambda lib_dir: os.path.join(libs_path, lib_dir), lib_dirs))
return abs_lib_paths
def main():
"""
Generate documentation and optionally zip it up.
"""
parser = argparse.ArgumentParser(description="Generate all doxygen and optionally zip it.")
parser.add_argument("-r", "--root", action="store", required=False, dest="root", help="CSDK repo root path. This defaults to the current working directory.")
parser.add_argument("-z", "--zip", action="store_true", required=False, help="Zip all doxygen output.")
args = parser.parse_args()
sdk_root = args.root
doZip = args.zip
# If the root folder is not give, use the current working directory.
if( sdk_root == None ):
sdk_root = os.getcwd()
# Get the absolute paths to all of the libraries in the CSDK.
abs_sdk_root = os.path.abspath(sdk_root)
abs_lib_paths = get_lib_paths(abs_sdk_root)
abs_doxy_paths = []
doxygen_warnings_flag = False
# Generate the doxygen for all of the libraries.
for abs_lib_path in abs_lib_paths:
abs_doxy_path = os.path.join(abs_lib_path, "docs", "doxygen")
if os.path.exists(abs_doxy_path):
os.chdir(abs_lib_path)
print(abs_lib_path)
# If there is something printed by doxygen, then it represents a warning.
doxygen_warnings_flag = run_cmd("doxygen docs/doxygen/config.doxyfile") or doxygen_warnings_flag
abs_doxy_paths.append(abs_doxy_path)
# Generate the doxygen for the CSDK last to use the tags from the libraries.
os.chdir(abs_sdk_root)
print(abs_sdk_root)
doxygen_warnings_flag = run_cmd("doxygen docs/doxygen/config.doxyfile") or doxygen_warnings_flag
abs_doxy_paths.append(os.path.join(abs_sdk_root, "docs", "doxygen"))
# Zip up if desired.
if not(doxygen_warnings_flag) and doZip:
print(f"Zipping up to {abs_sdk_root}{os.path.sep}doxygen.zip...")
doxy_zip = zipfile.ZipFile("doxygen.zip", mode="w")
try:
for abs_doxy_path in abs_doxy_paths:
abs_output_dir = os.path.join(abs_doxy_path, "output")
for out_root, _, out_files in os.walk(abs_output_dir):
rel_out_root = os.path.relpath(out_root, abs_sdk_root)
for out_file in out_files:
doxy_zip.write(os.path.join(rel_out_root, out_file))
finally:
doxy_zip.close()
# Return failure exit code if doxygen generation resulted in warnings.
if doxygen_warnings_flag == False:
sys.exit(0)
else:
sys.exit(1)
if __name__ == "__main__":
main()