-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgenerate_readme.py
executable file
·54 lines (39 loc) · 1.32 KB
/
generate_readme.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
#!/usr/bin/python3
from collections import namedtuple
import sys
INCLUDE_MARKER = "__INCLUDE_RUST_DOC__"
Template = namedtuple("Template", ["header", "footer", "doc_path", "start"])
def read_rust_doc_lines(path):
with open(path, "r") as rust_doc:
for line in rust_doc:
if line.startswith('//! '):
yield line[4:]
elif line.startswith('//!'):
yield line[3:]
else:
break
def parse_template_file(path):
content = [line for line in open(path, "r")]
try:
marker_position = [n for (n, line) in enumerate(content)
if line.startswith(INCLUDE_MARKER)][0]
except IndexError:
raise Exception("Missing include marker")
include_info = content[marker_position].split('$')
return Template(
header=content[0:marker_position], footer=content[marker_position+1:],
doc_path=include_info[1], start=include_info[2],
)
template = parse_template_file("readme_template")
doc = read_rust_doc_lines(template.doc_path)
output = sys.stdout
for line in template.header:
output.write(line)
for line in doc:
if line.startswith(template.start):
output.write(line)
break
for line in doc:
output.write(line)
for line in template.footer:
output.write(line)