1997-06-02 17:57:10 +00:00
|
|
|
# Generate custlib.tex, which is a site-specific library document.
|
|
|
|
|
|
|
|
# Phase I: list all the things that can be imported
|
|
|
|
|
2002-10-16 14:59:02 +00:00
|
|
|
import glob
|
|
|
|
import os.path
|
|
|
|
import sys
|
|
|
|
|
|
|
|
modules = {}
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
for modname in sys.builtin_module_names:
|
2002-10-16 14:59:02 +00:00
|
|
|
modules[modname] = modname
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
for dir in sys.path:
|
|
|
|
# Look for *.py files
|
2002-10-16 14:59:02 +00:00
|
|
|
filelist = glob.glob(os.path.join(dir, '*.py'))
|
1997-06-02 17:57:10 +00:00
|
|
|
for file in filelist:
|
2000-10-07 12:50:05 +00:00
|
|
|
path, file = os.path.split(file)
|
2002-10-16 14:59:02 +00:00
|
|
|
base, ext = os.path.splitext(file)
|
|
|
|
modules[base.lower()] = base
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
# Look for shared library files
|
2002-10-16 14:59:02 +00:00
|
|
|
filelist = (glob.glob(os.path.join(dir, '*.so')) +
|
|
|
|
glob.glob(os.path.join(dir, '*.sl')) +
|
|
|
|
glob.glob(os.path.join(dir, '*.o')) )
|
1997-06-02 17:57:10 +00:00
|
|
|
for file in filelist:
|
2000-10-07 12:50:05 +00:00
|
|
|
path, file = os.path.split(file)
|
2002-10-16 14:59:02 +00:00
|
|
|
base, ext = os.path.splitext(file)
|
|
|
|
if base[-6:] == 'module':
|
|
|
|
base = base[:-6]
|
|
|
|
modules[base.lower()] = base
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
# Minor oddity: the types module is documented in libtypes2.tex
|
|
|
|
if modules.has_key('types'):
|
2002-10-16 14:59:02 +00:00
|
|
|
del modules['types']
|
|
|
|
modules['types2'] = None
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
# Phase II: find all documentation files (lib*.tex)
|
|
|
|
# and eliminate modules that don't have one.
|
|
|
|
|
2002-10-16 14:59:02 +00:00
|
|
|
docs = {}
|
|
|
|
filelist = glob.glob('lib*.tex')
|
1997-06-02 17:57:10 +00:00
|
|
|
for file in filelist:
|
2002-10-16 14:59:02 +00:00
|
|
|
modname = file[3:-4]
|
|
|
|
docs[modname] = modname
|
1997-06-02 17:57:10 +00:00
|
|
|
|
2002-10-16 14:59:02 +00:00
|
|
|
mlist = modules.keys()
|
|
|
|
mlist = filter(lambda x, docs=docs: docs.has_key(x), mlist)
|
1997-06-02 17:57:10 +00:00
|
|
|
mlist.sort()
|
2002-10-16 14:59:02 +00:00
|
|
|
mlist = map(lambda x, docs=docs: docs[x], mlist)
|
1997-06-02 17:57:10 +00:00
|
|
|
|
2002-10-16 14:59:02 +00:00
|
|
|
modules = mlist
|
1997-06-02 17:57:10 +00:00
|
|
|
|
|
|
|
# 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}
|
2000-10-07 12:50:05 +00:00
|
|
|
\\makeindex % tell \\index to actually write the .idx file
|
1997-06-02 17:57:10 +00:00
|
|
|
\\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
|
2000-10-07 12:50:05 +00:00
|
|
|
print """\\input{custlib.ind} % Index
|
1997-06-02 17:57:10 +00:00
|
|
|
\\end{document}"""
|