-
Notifications
You must be signed in to change notification settings - Fork 844
/
Copy pathglossary.py
70 lines (45 loc) · 1.85 KB
/
glossary.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
"""
Builds a glossary page containing definition lists found in articles
and pages, and adds a `definitions` variable visible to all page templates.
"""
import bs4
from pelican import signals
class Definitions():
definitions = []
exclude = []
def make_title(def_title):
return def_title.text
def make_def(def_title):
return ''.join(str(t) for t in def_title.find_next('dd').contents)
def make_anchor(def_title):
return def_title.text.lower().replace(' ', '-')
def set_definitions(generator, metadata):
generator.context['definitions'] = Definitions.definitions
def get_excludes(pelican):
Definitions.exclude = pelican.settings.get('GLOSSARY_EXCLUDE', [])
def parse_content(content):
soup = bs4.BeautifulSoup(content._content, 'html.parser')
for def_list in soup.find_all('dl'):
defns = []
for def_title in def_list.find_all('dt'):
if def_title.text not in Definitions.exclude:
anchor_name = make_anchor(def_title)
anchor_tag = bs4.Tag(name="a", attrs={'name': anchor_name})
index = def_list.parent.index(def_list)-1
def_list.parent.insert(index, anchor_tag)
defns.append(
{'title': make_title(def_title),
'definition': make_def(def_title),
'anchor': anchor_name,
'source': content})
for defn in defns:
defn['see_also'] = [d for d in defns if d is not defn]
Definitions.definitions += defns
content._content = str(soup)
def parse_articles(generator):
for article in generator.articles:
parse_content(article)
def register():
signals.initialized.connect(get_excludes)
signals.article_generator_finalized.connect(parse_articles)
signals.page_generator_context.connect(set_definitions)