-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathbuild_docs.py
120 lines (98 loc) · 3.73 KB
/
build_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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import glob
import re
import textwrap
from copy import copy
from typing import Callable, Type
import kick
DOC_STRING_REGEX = re.compile(r"\[\[(?P<what>[^\]]*)]]")
DISPLAY_REGEX = re.compile(r"{{(?P<item>[^}]*)}}")
SHOW_ALL_REGEX = re.compile(r"|\[(?P<item>[^|]*)]|")
H3_REGEX = re.compile(r"(?P<text>[a-zA-Z0-9_-]*)<br>\n-----------")
CODEBLOCK_REGEX = re.compile(r"`(?P<code>[^`]*)`")
HEADER = """
<head>
<link rel="stylesheet" href="style.css">
</head>"""
RAW_DOCS_DIR = "raw_docs"
FINAL_DOCS_DIR = "docs"
IGNORE_FORMAT_TEXT = "!IGNORE-FORMAT"
def convert_file(fp: str) -> None:
before_fp = fp
after_fp = fp.replace(RAW_DOCS_DIR, FINAL_DOCS_DIR)
with open(before_fp, "r", encoding="utf-8") as f:
text = f.read()
if text.splitlines()[0] != IGNORE_FORMAT_TEXT:
for find in SHOW_ALL_REGEX.findall(text):
after = "{{x}}".replace("x", find) + f"[[{find}]]"
text = text.replace(f"|[{find}]|", after)
# Docstring
for find in DOC_STRING_REGEX.findall(text):
try:
item = eval(f"kick.{find}")
doc = item.__doc__ or ""
except Exception as e:
pass
else:
doc = textwrap.dedent(copy(doc))
if doc and doc.splitlines()[1].strip() == "|coro|":
temp = doc.splitlines()
temp.pop(0)
temp.pop(0)
doc = "\n".join(temp)
ret = []
for line in doc.splitlines():
if line.startswith(" "):
line = f'<span style="margin-left: 30px">{line}</span>'
line += "<br>"
ret.append(line)
text = text.replace(f"[[{find}]]", "\n".join(ret))
for find in DISPLAY_REGEX.findall(text):
try:
item = eval(f"kick.{find}")
except Exception as e:
pass
else:
doc = copy(item.__doc__ or "")
class_ = ""
tag = 3
if doc and doc.splitlines()[1].strip() == "|coro|":
prefix = "async def "
temp = doc.splitlines()
temp.pop(0)
temp.pop(0)
doc = "\n".join(temp)
elif getattr(item, "__is_decorator__", False) is True:
prefix = "@"
class_ = "at"
elif isinstance(item, Type):
prefix = "class "
tag = 2
elif isinstance(item, Callable):
prefix = "def "
else:
prefix = ""
if prefix and not class_:
class_ = prefix.split(" ")[0]
after = f"""
<a href="#{find}" class="h{tag} hidden" id="{find}">
<span class="{class_}">
{prefix}
</span>
{find}
</a>
"""
text = text.replace("{{x}}".replace("x", find), textwrap.dedent(after))
for find in H3_REGEX.findall(text):
item = f"{find}<br>\n-----------"
text = text.replace(item, f'<span class="h4">{find}</span>')
# Codeblock hyperlinks
for find in CODEBLOCK_REGEX.findall(text):
after = f'<a href="#{find}" class="hidden">`{find}`</a>'
text = text.replace(f"`{find}`", after)
with open(after_fp, "w", encoding="utf-8") as f:
f.write(f"{HEADER}\n{text}")
files = glob.glob(f"{RAW_DOCS_DIR}/*.md")
for file in files:
print(f"Starting on {file}...")
convert_file(file)
print(f"Finished {file}")