forked from PPPLDeepLearning/plasma-python
-
Notifications
You must be signed in to change notification settings - Fork 1
/
makedocs.py
48 lines (40 loc) · 1.34 KB
/
makedocs.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
#!/usr/bin/env python
import importlib
import inspect
modules = [
"plasma.primitives.shots",
"plasma.models.builder",
"plasma.models.loader",
"plasma.models.runner",
"plasma.models.targets",
"plasma.models.mpi_runner",
"plasma.preprocessor.normalize",
"plasma.preprocessor.preprocess",
"plasma.utils.evaluation",
"plasma.utils.performance",
"plasma.utils.processing"
]
modules = {name: importlib.import_module(name) for name in modules}
documented = []
for moduleName, module in modules.items():
for objName in dir(module):
obj = getattr(module, objName)
if not objName.startswith("_") and callable(obj) and obj.__module__ == moduleName:
print objName, obj
documented.append(moduleName + "." + objName)
if inspect.isclass(obj):
open("docs/" + moduleName + "." + objName + ".rst", "w").write(''':orphan:
{0}
{1}
.. autoclass:: {0}
:members:
:special-members: __init__, __add__
:inherited-members:
:show-inheritance:
'''.format(moduleName + "." + objName, "=" * (len(moduleName) + len(objName) + 1)))
else:
open("docs/" + moduleName + "." + objName + ".rst", "w").write(''':orphan:
{0}
{1}
.. autofunction:: {0}
'''.format(moduleName + "." + objName, "=" * (len(moduleName) + len(objName) + 1)))