blob: 0209a1a3f621c979cbe0ad72312e736ab396ab57 (
plain)
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
|
#! /usr/bin/env python
"""Script to convert raw module index data to module index."""
import os
import string
import sys
def parse_line(input):
lineno = string.split(input)[-1]
module = string.strip(input[:len(input)-(len(lineno)+1)])
return module, lineno
def cmp_items((s1, line1), (s2, line2)):
rc = cmp(string.lower(s1), string.lower(s2))
if rc == 0:
# Make the lower-case version come first since the upper-case
# version is usually a helper module for constants and such.
rc = cmp(s2, s1)
return rc
def main():
if sys.argv[1:]:
infile = sys.argv[1]
else:
infile = "-"
if infile == "-":
ifp = sys.stdin
ofp = sys.stdout
sys.stdout = sys.stderr
else:
ifp = open(infile)
base, ext = os.path.splitext(infile)
outfile = base + ".ind"
ofp = open(outfile, "w")
ofp.write("\\begin{theindex}\n\label{modindex}\n\n")
lines = ifp.readlines()
for i in range(len(lines)):
if lines[i][0] == '\\':
lines[i] = '\1' + lines[i]
lines = map(parse_line, lines)
lines.sort(cmp_items)
prev_letter = lines[0][0][0]
if prev_letter == '\1':
prev_letter = lines[0][0][1]
prev_letter = string.lower(prev_letter)
for module, lineno in lines:
if module[0] == '\1':
module = module[1:]
if string.lower(module[0]) != prev_letter:
ofp.write("\n \\indexspace\n\n")
prev_letter = string.lower(module[0])
ofp.write(" \\item {\\tt %s}, %s\n" % (module, lineno))
ofp.write("\n\\end{theindex}\n")
if __name__ == "__main__":
main()
|