summaryrefslogtreecommitdiff
path: root/Doc/tools/custlib.py
blob: 15f07baf0e534ff9884ca158af30525dc0a9633d (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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# Generate custlib.tex, which is a site-specific library document.

# Phase I: list all the things that can be imported

import glob
import os.path
import sys

modules = {}

for modname in sys.builtin_module_names:
    modules[modname] = modname

for dir in sys.path:
    # Look for *.py files
    filelist = glob.glob(os.path.join(dir, '*.py'))
    for file in filelist:
        path, file = os.path.split(file)
        base, ext = os.path.splitext(file)
        modules[base.lower()] = base

    # Look for shared library files
    filelist = (glob.glob(os.path.join(dir, '*.so')) +
                glob.glob(os.path.join(dir, '*.sl')) +
                glob.glob(os.path.join(dir, '*.o')) )
    for file in filelist:
        path, file = os.path.split(file)
        base, ext = os.path.splitext(file)
        if base[-6:] == 'module':
            base = base[:-6]
        modules[base.lower()] = base

# Minor oddity: the types module is documented in libtypes2.tex
if modules.has_key('types'):
    del modules['types']
    modules['types2'] = None

# Phase II: find all documentation files (lib*.tex)
#           and eliminate modules that don't have one.

docs = {}
filelist = glob.glob('lib*.tex')
for file in filelist:
    modname = file[3:-4]
    docs[modname] = modname

mlist = modules.keys()
mlist = filter(lambda x, docs=docs: docs.has_key(x), mlist)
mlist.sort()
mlist = map(lambda x, docs=docs: docs[x], mlist)

modules = mlist

# Phase III: write custlib.tex

# Write the boilerplate
# XXX should be fancied up.
print """\documentstyle[twoside,11pt,myformat]{report}
\\title{Python Library Reference}
\\input{boilerplate}
\\makeindex                     % tell \\index to actually write the .idx file
\\begin{document}
\\pagenumbering{roman}
\\maketitle
\\input{copyright}
\\begin{abstract}
\\noindent This is a customized version of the Python Library Reference.
\\end{abstract}
\\pagebreak
{\\parskip = 0mm \\tableofcontents}
\\pagebreak\\pagenumbering{arabic}"""

for modname in mlist:
    print "\\input{lib%s}" % (modname,)

# Write the end
print """\\input{custlib.ind}                   % Index
\\end{document}"""