summaryrefslogtreecommitdiffstats
path: root/Doc/tools/modindex.py
blob: f85b909ddabc752de0c9541f0fcee479af58a7cd (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 = input[:len(input)-(len(lineno)+1)]
    return module, lineno
    return 


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\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()