From dd244a0b9eeef2d0d8f6a3375eee4b5f88067ac4 Mon Sep 17 00:00:00 2001 From: Fred Drake Date: Mon, 9 Feb 1998 22:17:52 +0000 Subject: Script to fix up the Library Reference index so it's less ugly. The docstring: """Combine similar index entries into an entry and subentries. For example: \item {foobar} (in module flotz), 23 \item {foobar} (in module whackit), 4323 becomes \item {foobar} \subitem in module flotz, 23 \subitem in module whackit, 4323 Note that an item which matches the format of a collapsable item but which isn't part of a group of similar items is not modified. """ This results in a much more readable index, with less repitition of text; especially for common method names. --- Doc/indfix.py | 89 +++++++++++++++++++++++++++++++++++++++++++++++++++++ Doc/tools/indfix.py | 89 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 178 insertions(+) create mode 100755 Doc/indfix.py create mode 100755 Doc/tools/indfix.py diff --git a/Doc/indfix.py b/Doc/indfix.py new file mode 100755 index 0000000..3435212 --- /dev/null +++ b/Doc/indfix.py @@ -0,0 +1,89 @@ +#! /usr/bin/env python + +"""Combine similar index entries into an entry and subentries. + +For example: + + \item {foobar} (in module flotz), 23 + \item {foobar} (in module whackit), 4323 + +becomes + + \item {foobar} + \subitem in module flotz, 23 + \subitem in module whackit, 4323 + +Note that an item which matches the format of a collapsable item but which +isn't part of a group of similar items is not modified. +""" +__version__ = '$Revision$' + +import re +import string +import StringIO +import sys + + +def strcasecmp(e1, e2, lower=string.lower): + return cmp(lower(e1[1]), lower(e2[1])) or cmp(e1, e2) + + +def dump_entries(ofp, entries): + if len(entries) == 1: + ofp.write(" \\item %s (%s)%s\n" % entries[0]) + return + ofp.write(" \item %s\n" % entries[0][0]) + # now sort these in a case insensitive manner: + entries.sort(strcasecmp) + for xxx, subitem, pages in entries: + ofp.write(" \subitem %s%s\n" % (subitem, pages)) + + +breakable_re = re.compile(r" \\item (.*) [(](.*)[)]((?:, \d+)+)") + +def main(): + import getopt + outfile = None + opts, args = getopt.getopt(sys.argv[1:], "o:") + for opt, val in opts: + if opt in ("-o", "--output"): + outfile = val + filename = args[0] + outfile = outfile or filename + if filename == "-": + fp = sys.stdin + else: + fp = open(filename) + ofp = StringIO.StringIO() + item, subitem = None, None + entries = [] + while 1: + line = fp.readline() + if not line: + break + m = breakable_re.match(line) + if m: + entry = m.group(1, 2, 3) + if entries: + if entries[-1][0] != entry[0]: + dump_entries(ofp, entries) + entries = [] + entries.append(entry) + elif entries: + dump_entries(ofp, entries) + entries = [] + ofp.write(line) + else: + pass + ofp.write(line) + fp.close() + if outfile == "-": + fp = sys.stdout + else: + fp = open(outfile, "w") + fp.write(ofp.getvalue()) + fp.close() + + +if __name__ == "__main__": + main() diff --git a/Doc/tools/indfix.py b/Doc/tools/indfix.py new file mode 100755 index 0000000..3435212 --- /dev/null +++ b/Doc/tools/indfix.py @@ -0,0 +1,89 @@ +#! /usr/bin/env python + +"""Combine similar index entries into an entry and subentries. + +For example: + + \item {foobar} (in module flotz), 23 + \item {foobar} (in module whackit), 4323 + +becomes + + \item {foobar} + \subitem in module flotz, 23 + \subitem in module whackit, 4323 + +Note that an item which matches the format of a collapsable item but which +isn't part of a group of similar items is not modified. +""" +__version__ = '$Revision$' + +import re +import string +import StringIO +import sys + + +def strcasecmp(e1, e2, lower=string.lower): + return cmp(lower(e1[1]), lower(e2[1])) or cmp(e1, e2) + + +def dump_entries(ofp, entries): + if len(entries) == 1: + ofp.write(" \\item %s (%s)%s\n" % entries[0]) + return + ofp.write(" \item %s\n" % entries[0][0]) + # now sort these in a case insensitive manner: + entries.sort(strcasecmp) + for xxx, subitem, pages in entries: + ofp.write(" \subitem %s%s\n" % (subitem, pages)) + + +breakable_re = re.compile(r" \\item (.*) [(](.*)[)]((?:, \d+)+)") + +def main(): + import getopt + outfile = None + opts, args = getopt.getopt(sys.argv[1:], "o:") + for opt, val in opts: + if opt in ("-o", "--output"): + outfile = val + filename = args[0] + outfile = outfile or filename + if filename == "-": + fp = sys.stdin + else: + fp = open(filename) + ofp = StringIO.StringIO() + item, subitem = None, None + entries = [] + while 1: + line = fp.readline() + if not line: + break + m = breakable_re.match(line) + if m: + entry = m.group(1, 2, 3) + if entries: + if entries[-1][0] != entry[0]: + dump_entries(ofp, entries) + entries = [] + entries.append(entry) + elif entries: + dump_entries(ofp, entries) + entries = [] + ofp.write(line) + else: + pass + ofp.write(line) + fp.close() + if outfile == "-": + fp = sys.stdout + else: + fp = open(outfile, "w") + fp.write(ofp.getvalue()) + fp.close() + + +if __name__ == "__main__": + main() -- cgit v0.12