-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathgen_doc_stubs.py
51 lines (36 loc) · 1.79 KB
/
gen_doc_stubs.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
# Generates virtual doc files for the mkdocs site.
# You can also run this script directly to actually write out those files, as a preview.
import mkdocs_gen_files
from typing import Any
import markdown as md
import json
handler = mkdocs_gen_files.config['plugins']['mkdocstrings'].get_handler('crystal')
# get the `update_env` method of the handler
update_env = handler.update_env
# override the `update_env` method of the handler
def patched_update_env(markdown: md.Markdown, config: dict[str, Any]) -> None:
update_env(markdown, config)
def from_json(data):
return json.loads(data.removesuffix('of Nil'))
# patch the filter
handler.env.filters["from_json"] = from_json
# patch the method
handler.update_env = patched_update_env
root = handler.collector.root
for typ in root.lookup("Athena").walk_types():
# Athena::Validator::Violation -> Validator/Violation/index.md
filename = '/'.join(typ.abs_id.split('::')[2:] + ['index.md'])
# Rename the root `index.md` to `top_level.md` so that the user lands on the introduction page instead of the root component module docs.
# But only do this for non-framework components as the site itself is the contextual docs for the framework.
if typ.full_name != 'Athena::Framework' and filename == 'index.md':
filename = 'top_level.md'
with mkdocs_gen_files.open(filename, 'w') as f:
f.write(f'# ::: {typ.abs_id}\n\n')
if typ.locations:
mkdocs_gen_files.set_edit_path(filename, typ.locations[0].url)
for typ in root.types:
# Write the entry of a top-level alias (e.g. `AED`) to its appropriate section.
if typ.kind == 'alias':
# Athena::Validator::Annotations -> Validator/aliases.md
with mkdocs_gen_files.open('aliases.md', 'a') as f:
f.write(f'::: {typ.abs_id}\n\n')