-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathgenerate-markdown.py
executable file
·40 lines (32 loc) · 1.47 KB
/
generate-markdown.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
#!/usr/bin/env python3
import sys
class MarkdownGenerator:
def __init__(self):
self.in_question = False
self.first_line_in_question = False
self.prefix = ""
self.qnum = 0
def process_line(self, line, outfile):
if self.in_question:
if not line.startswith("</h3>"):
line = line.lstrip()
if self.first_line_in_question:
self.qnum += 1
self.prefix = "%02d. " % self.qnum
self.first_line_in_question = False
print(self.prefix, line, end='', file=outfile)
self.prefix = " "
else:
self.in_question = False
elif line.startswith("<h3 class=question id="):
self.in_question = True
self.first_line_in_question = True
def generate_markdown(self, infile=sys.stdin, outfile=sys.stdout):
print("""# [Self-Review Questionnaire: Security and Privacy](https://w3ctag.github.io/security-questionnaire/)
The full questionnaire is at https://w3ctag.github.io/security-questionnaire/.
For your convenience, a copy of the questionnaire's questions is included here in Markdown, so you can easily include your answers in an [explainer](https://github.com/w3ctag/w3ctag.github.io/blob/master/explainers.md).
---
""", file=outfile)
[self.process_line(line, outfile) for line in infile]
if __name__ == '__main__':
MarkdownGenerator().generate_markdown()