-
-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathgenerate_indexes.py
executable file
·100 lines (84 loc) · 3.41 KB
/
generate_indexes.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
#!/usr/bin/env python
"""
Automatically generate "Docs for other versions".
"""
from __future__ import print_function
import codecs
import os
import os.path
import sys
import re
def main():
dirs = ['latest', 'dev']
# Simply update the releases list in each $RELEASEDIR/index.html.
# This should be idempotent.
versions = {}
for releasedir in dirs:
with codecs.open(os.path.join(releasedir, "index.html"), "r", "utf8") as f:
lines = f.readlines()
# Find the release version
for line in lines:
m = re.search(r'<a href="#">SymPy (.*?) documentation</a>', line)
if m:
versions[releasedir] = m.group(1)
break
else:
raise RuntimeError(f"Could not find the version for {releasedir}")
releases = [('latest', f'SymPy {versions["latest"]} (latest release)'),
('dev', f'SymPy {versions["dev"]} (development version)')]
for releasedir in dirs:
with codecs.open(os.path.join(releasedir, "index.html"), "r", "utf8") as f:
lines = f.readlines()
# Find where in the file we need to edit
context = [
'<div class="sphinxsidebarwrapper">',
'<p class="logo">',
'<img class="logo" src="_static/sympylogo.png" alt="Logo"/>',
'</a></p>'
]
redirect = 'http-equiv="refresh"'
contexti = 0
for linei, line in enumerate(lines):
# Did we match all we need to match?
if contexti >= len(context):
break
# When we find a partial match, move to the next line to see if the
# match continues. Otherwise, we start over.
if context[contexti] in line:
contexti += 1
else:
contexti = 0
inserti = linei
# If we didn't find a match in the whole file, we need to stop and fix something.
if contexti < len(context):
if any(redirect in line for line in lines):
continue
print("Couldn't find where to insert Docs for other versions in {0}".format(releasedir))
sys.exit(0)
# Do we want to delete anything? Is there a table there already?
if "Documentation version" in lines[linei]:
# Where does the current table end?
# We want endi to be the first line not part of the current table.
while linei < len(lines):
linei += 1
if 'p class="topless"' not in lines[linei]:
break
endi = linei
# Remove the current table and insert a new one.
del lines[inserti:endi]
for insertreleasedir, insertrelease in reversed(releases):
if insertreleasedir == releasedir:
lines.insert(inserti, ' <p class="topless">{0}</p>\n'.format(
insertrelease
))
else:
lines.insert(inserti, ' <p class="topless"><a href="../{0}/index.html">{1}</a></p>\n'.format(
insertreleasedir,
insertrelease
))
lines.insert(inserti, " <h4>Documentation version</h4>\n")
# Write the changed file back out.
with codecs.open(os.path.join(releasedir, "index.html"), "w", "utf8") as f:
f.writelines(lines)
if __name__ == '__main__':
sys.exit(main())