blob: 7501ace0dc456069065454cb126ee7ba37fd91c9 [file] [log] [blame]
Guido van Rossume83e3801995-03-17 16:01:35 +00001# Makefile for Python documentation
2# ---------------------------------
3#
Guido van Rossum73827c61995-03-20 13:00:32 +00004# See also the README file.
5#
Guido van Rossume83e3801995-03-17 16:01:35 +00006# This is a bit of a mess. The main documents are:
7# tut -- Tutorial (file tut.tex)
8# lib -- Library Reference (file lib.tex, inputs lib*.tex)
Guido van Rossume83e3801995-03-17 16:01:35 +00009# ext -- Extending and Embedding (file ext.tex)
Guido van Rossum9231c8f1997-05-15 21:43:21 +000010# api -- Python-C API Reference
Guido van Rossume83e3801995-03-17 16:01:35 +000011#
Guido van Rossum1f175431996-10-22 20:00:02 +000012# The Reference Manual is now maintained as a FrameMaker document.
13# See the subdirectory ref; PostScript is included as ref/ref.ps.
14# (In the future, the Tutorial will also be converted to FrameMaker;
15# the other documents will be maintained in a text format such
16# as LaTeX or perhaps TIM.)
17#
Guido van Rossume83e3801995-03-17 16:01:35 +000018# The main target "make all" creates DVI and PostScript for these
19# four. You can also do "make lib" (etc.) to process individual
20# documents.
21#
Guido van Rossume83e3801995-03-17 16:01:35 +000022# There's one local style file: myformat.sty. This defines a number
23# of macros that are similar in name and intent as macros in Texinfo
24# (e.g. \code{...} and \emph{...}), as well as a number of
25# environments for formatting function and data definitions, also in
26# the style of Texinfo.
27#
28# Everything is processed by LaTeX. The following tools are used:
29# latex
30# makeindex
31# dvips
Guido van Rossume83e3801995-03-17 16:01:35 +000032#
33# There's a problem with generating the index which has been solved by
34# a sed command applied to the index file. The shell script fix_hack
35# does this (the Makefile takes care of calling it).
36#
37# To preview the dvi files produced by LaTeX it would be useful to
38# have xdvi as well.
39#
40# Additional targets attempt to convert selected LaTeX sources to
41# various other formats. These are generally site specific because
42# the tools used are all but universal. These targets are:
Guido van Rossum9231c8f1997-05-15 21:43:21 +000043# l2h -- convert tut, lib, ext, api from LaTeX to HTML
Guido van Rossum73827c61995-03-20 13:00:32 +000044# See the README file for more info on these targets.
Guido van Rossume83e3801995-03-17 16:01:35 +000045
Guido van Rossum73827c61995-03-20 13:00:32 +000046# Customizations -- you *may* have to edit these
Guido van Rossume83e3801995-03-17 16:01:35 +000047
Guido van Rossum73827c61995-03-20 13:00:32 +000048# Where are the various programs?
49LATEX= latex
Fred Drake3b26eed1998-02-16 17:06:10 +000050PDFLATEX= pdflatex
Guido van Rossum73827c61995-03-20 13:00:32 +000051BIBTEX= bibtex
Guido van Rossum5344d4f1997-10-05 18:51:02 +000052DVIPS= dvips -f -N0
Fred Drake126d8401998-02-04 19:54:40 +000053DISTILL= distill
Guido van Rossum73827c61995-03-20 13:00:32 +000054MAKEINDEX= makeindex
Fred Drakef93f1011996-10-29 16:07:46 +000055L2H= latex2html
Guido van Rossum0f280b61997-12-01 18:50:09 +000056L2HARGS= -address $$LOGNAME@`domainname`
Guido van Rossum73827c61995-03-20 13:00:32 +000057
58# Install destination -- not used now but might be useful some time...
59DESTDIR= /usr/local
60LIBDESTDIR= $DESTDIR/lib
61LIBDEST= $LIBDESTDIR/python
62DOCDESTDIR= $LIBDEST/doc
63
Fred Drake05dd3c01997-12-29 17:17:54 +000064# This is only used for .info generation:
65EMACS= emacs
66PYTHON= python
67MAKEINFO= makeinfo
Fred Drake6eab2fb1998-02-13 03:23:33 +000068PARTPARSEOBJ= partparse.pyc
69PARTPARSE= $(PYTHON) $(PARTPARSEOBJ)
Fred Drake05dd3c01997-12-29 17:17:54 +000070
Guido van Rossum73827c61995-03-20 13:00:32 +000071# Ideally, you shouldn't need to edit beyond this point
Guido van Rossum5b343731992-07-07 09:06:34 +000072
Fred Drake33d05b91998-01-13 16:33:09 +000073VERSION=1.5
74
Fred Drake04cf4dc1998-02-12 22:33:50 +000075DVIFILES= api.dvi ext.dvi lib.dvi tut.dvi
76PDFFILES= api.pdf ext.pdf lib.pdf tut.pdf
77PSFILES= api.ps ext.ps lib.ps tut.ps
78
Guido van Rossume83e3801995-03-17 16:01:35 +000079# Main target
Guido van Rossumeb8d5031996-08-09 21:46:05 +000080all: all-ps
81
Fred Drake04cf4dc1998-02-12 22:33:50 +000082all-dvi: $(DVIFILES)
83all-pdf: $(PDFFILES)
84all-ps: $(PSFILES)
Guido van Rossum20aca5a1991-01-25 13:29:04 +000085
Fred Drake5fd242b1998-02-17 18:20:30 +000086# This target gets both the PDF and PS files updated; the all-pdf target
87# above doesn't ensure that both are done if the "alternate" rule (using
88# pdflatex) for PDF generation is used.
Fred Drakeddae4141998-02-17 15:45:25 +000089#
90all-formats: $(PSFILES) $(PDFFILES)
91
Guido van Rossume83e3801995-03-17 16:01:35 +000092# Individual document fake targets
Guido van Rossumeb8d5031996-08-09 21:46:05 +000093tut: tut.ps
94lib: lib.ps
Guido van Rossumeb8d5031996-08-09 21:46:05 +000095ext: ext.ps
Guido van Rossum9231c8f1997-05-15 21:43:21 +000096api: api.ps
Guido van Rossume83e3801995-03-17 16:01:35 +000097
Fred Drakedd946761998-02-18 16:02:14 +000098# All formats for a single document
99api-all: api.dvi api.pdf api.ps l2hapi
100ext-all: ext.dvi ext.pdf ext.ps l2hext
101lib-all: lib.dvi lib.pdf lib.ps l2hlib
102tut-all: tut.dvi tut.pdf tut.ps l2htut
103
104
Fred Drake126d8401998-02-04 19:54:40 +0000105# Rules to build PostScript and PDF formats
106.SUFFIXES: .dvi .ps .pdf
107
108.dvi.ps:
109 $(DVIPS) $< >$@
110
Fred Drakeddae4141998-02-17 15:45:25 +0000111#.ps.pdf:
112# $(DISTILL) $<
Fred Drake126d8401998-02-04 19:54:40 +0000113
Fred Drake3b26eed1998-02-16 17:06:10 +0000114# An alternate formulation of PDF creation; requires latex format with
115# pdftex. To use this instead of the Acrobat distiller solution, comment
116# out the above .ps.pdf rule and uncomment this rule. This was tested
117# using a pre-release of the teTeX distribution. See
118# http://www.tug.org/tetex/ for more information on getting & using teTeX.
119# This rule avoids creation of the intermediate PostScript files and uses
120# only free software.
121#
Fred Drakeddae4141998-02-17 15:45:25 +0000122.dvi.pdf:
123 $(PDFLATEX) $*
Fred Drake3b26eed1998-02-16 17:06:10 +0000124
Guido van Rossume83e3801995-03-17 16:01:35 +0000125# Dependencies
Fred Drake5d8f0ed1998-02-11 14:43:38 +0000126COMMONTEX=myformat.sty copyright.tex boilerplate.tex
127
128tut.dvi lib.dvi ext.dvi api.dvi: fix_hack $(COMMONTEX)
Guido van Rossum16d6e711994-08-08 12:30:22 +0000129
Guido van Rossume83e3801995-03-17 16:01:35 +0000130# Tutorial document
Guido van Rossum16d6e711994-08-08 12:30:22 +0000131tut.dvi: tut.tex
Guido van Rossum73827c61995-03-20 13:00:32 +0000132 $(LATEX) tut
133 $(LATEX) tut
Guido van Rossumeb8d5031996-08-09 21:46:05 +0000134
Guido van Rossum16d6e711994-08-08 12:30:22 +0000135# LaTeX source files for the Python Library Reference
136LIBFILES = lib.tex \
Guido van Rossum40006cf1996-08-19 22:58:03 +0000137 libintro.tex libobjs.tex libtypes.tex libexcs.tex libfuncs.tex \
138 libpython.tex libsys.tex libtypes2.tex libtraceback.tex libpickle.tex \
139 libshelve.tex libcopy.tex libmarshal.tex libimp.tex libparser.tex \
140 libbltin.tex libmain.tex libstrings.tex libstring.tex libregex.tex \
141 libregsub.tex libstruct.tex libmisc.tex libmath.tex librand.tex \
142 libwhrandom.tex libarray.tex liballos.tex libos.tex libtime.tex \
143 libgetopt.tex libtempfile.tex liberrno.tex libsomeos.tex libsignal.tex \
144 libsocket.tex libselect.tex libthread.tex libunix.tex libposix.tex \
145 libppath.tex libpwd.tex libgrp.tex libcrypt.tex libdbm.tex libgdbm.tex \
146 libtermios.tex libfcntl.tex libposixfile.tex libsyslog.tex libpdb.tex \
147 libprofile.tex libwww.tex libcgi.tex liburllib.tex libhttplib.tex \
148 libftplib.tex libgopherlib.tex libnntplib.tex liburlparse.tex \
149 libhtmllib.tex libsgmllib.tex librfc822.tex libmimetools.tex \
150 libbinascii.tex libmm.tex libaudioop.tex libimageop.tex libaifc.tex \
151 libjpeg.tex librgbimg.tex libcrypto.tex libmd5.tex libmpz.tex \
152 librotor.tex libmac.tex libctb.tex libmacconsole.tex libmacdnr.tex \
153 libmacfs.tex libmacos.tex libmacostools.tex libmactcp.tex \
154 libmacspeech.tex libmacui.tex libstdwin.tex libsgi.tex libal.tex \
155 libcd.tex libfl.tex libfm.tex libgl.tex libimgfile.tex libsun.tex \
Guido van Rossuma80c3981996-10-22 01:12:13 +0000156 libxdrlib.tex libimghdr.tex \
157 librestricted.tex librexec.tex libbastion.tex \
Guido van Rossum3dd68d31996-12-31 02:24:54 +0000158 libformatter.tex liboperator.tex libsoundex.tex libresource.tex \
Guido van Rossum7f3b0421997-03-27 14:56:18 +0000159 libstat.tex libstrio.tex libundoc.tex libmailcap.tex libglob.tex \
Guido van Rossume76b7a81997-04-27 21:25:52 +0000160 libuser.tex libanydbm.tex librandom.tex libsite.tex libwhichdb.tex \
Guido van Rossum41c302f1997-06-02 17:36:12 +0000161 libbase64.tex libfnmatch.tex libquopri.tex libzlib.tex libsocksvr.tex \
Fred Drake18600a41997-07-18 20:43:27 +0000162 libmailbox.tex libcommands.tex libcmath.tex libni.tex libgzip.tex \
Guido van Rossum36764b81997-08-30 20:02:25 +0000163 libpprint.tex libcode.tex libmimify.tex libre.tex libmacic.tex \
Guido van Rossum9cb64801997-12-29 20:01:55 +0000164 libuserdict.tex libdis.tex libxmllib.tex libqueue.tex \
Fred Drake8ff4b8b1998-02-18 17:19:53 +0000165 liblocale.tex libbasehttp.tex libcopyreg.tex libsymbol.tex libtoken.tex \
166 libframework.tex libminiae.tex
Guido van Rossum16d6e711994-08-08 12:30:22 +0000167
Guido van Rossume83e3801995-03-17 16:01:35 +0000168# Library document
Fred Drake4be00711998-02-09 22:18:42 +0000169lib.dvi: modindex.py indfix.py $(LIBFILES)
Guido van Rossumb83241c1992-03-06 10:56:42 +0000170 touch lib.ind
Fred Drake34252f91998-01-02 03:01:47 +0000171 touch modules.ind
Guido van Rossum73827c61995-03-20 13:00:32 +0000172 $(LATEX) lib
Fred Drake34252f91998-01-02 03:01:47 +0000173 ./modindex.py modules.idx
Guido van Rossum95cd2ef1992-12-08 14:37:55 +0000174 ./fix_hack lib.idx
Fred Drakeb4d4e251996-11-11 21:03:01 +0000175 $(MAKEINDEX) lib.idx
Fred Drake4be00711998-02-09 22:18:42 +0000176 ./indfix.py lib.ind
Fred Drake34252f91998-01-02 03:01:47 +0000177 ./modindex.py modules.idx
Guido van Rossum73827c61995-03-20 13:00:32 +0000178 $(LATEX) lib
Guido van Rossumeb8d5031996-08-09 21:46:05 +0000179
Guido van Rossume83e3801995-03-17 16:01:35 +0000180# Extensions document
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000181ext.dvi: ext.tex
Guido van Rossum7a2dba21993-11-05 14:45:11 +0000182 touch ext.ind
Guido van Rossum73827c61995-03-20 13:00:32 +0000183 $(LATEX) ext
Guido van Rossum7a2dba21993-11-05 14:45:11 +0000184 ./fix_hack ext.idx
Fred Drakeb4d4e251996-11-11 21:03:01 +0000185 $(MAKEINDEX) ext.idx
Guido van Rossum73827c61995-03-20 13:00:32 +0000186 $(LATEX) ext
Guido van Rossumeb8d5031996-08-09 21:46:05 +0000187
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000188# Python-C API document
189api.dvi: api.tex
190 touch api.ind
191 $(LATEX) api
192 ./fix_hack api.idx
193 $(MAKEINDEX) api.idx
194 $(LATEX) api
Guido van Rossumeb8d5031996-08-09 21:46:05 +0000195
Guido van Rossume83e3801995-03-17 16:01:35 +0000196
197# The remaining part of the Makefile is concerned with various
Guido van Rossum73827c61995-03-20 13:00:32 +0000198# conversions, as described above. See also the README file.
Guido van Rossume83e3801995-03-17 16:01:35 +0000199
Fred Drake6eab2fb1998-02-13 03:23:33 +0000200.SUFFIXES: .py .pyc .pyo
201
202.py.pyo:
203 $(PYTHON) -O -c "import $*"
Fred Drake05dd3c01997-12-29 17:17:54 +0000204
205.py.pyc:
206 $(PYTHON) -c "import $*"
207
208.PRECIOUS: lib.texi
209
Fred Drake3d913ad1997-12-29 21:31:23 +0000210# The sed script in this target fixes a really nasty little condition in
211# libcgi.tex where \e has to be used in a group to get the right behavior,
212# and makeinfo can't handle a group with a leading @command. But at least
213# the info file gets generated.
214
Fred Drake6eab2fb1998-02-13 03:23:33 +0000215lib1.texi: lib*.tex texipre.dat texipost.dat $(PARTPARSEOBJ)
Fred Drake05dd3c01997-12-29 17:17:54 +0000216 $(PARTPARSE) -o lib1.texi `./whichlibs`
Fred Drake3d913ad1997-12-29 21:31:23 +0000217 sed 's/"{\\}n{\\}n/"\\n\\n/' lib1.texi >lib2.texi
218 mv lib2.texi lib1.texi
Fred Drake05dd3c01997-12-29 17:17:54 +0000219
220lib.texi: lib1.texi fix.el
221 $(EMACS) -batch -l fix.el -f save-buffer -kill
222 cp lib1.texi lib.texi
223
224python-lib.info: lib.texi
225 -$(MAKEINFO) --footnote-style end --fill-column 72 \
226 --paragraph-indent 0 lib.texi
227
Fred Drake13704a81997-12-29 22:04:44 +0000228# this is needed to prevent a second set of info files from being generated,
229# at least when using GNU make
230.PHONY: lib.info
231
Fred Drake05dd3c01997-12-29 17:17:54 +0000232lib.info: python-lib.info
233
Guido van Rossum73827c61995-03-20 13:00:32 +0000234# Targets to convert the manuals to HTML using Nikos Drakos' LaTeX to
235# HTML converter. For more info on this program, see
Guido van Rossume83e3801995-03-17 16:01:35 +0000236# <URL:http://cbl.leeds.ac.uk/nikos/tex2html/doc/latex2html/latex2html.html>.
Guido van Rossume83e3801995-03-17 16:01:35 +0000237
Guido van Rossum9cb64801997-12-29 20:01:55 +0000238# Note that LaTeX2HTML inserts references to an icons directory in
239# each page that it generates. I have placed a copy of this directory
240# in the distribution to simplify the process of creating a
241# self-contained HTML distribution; for this purpose I have also added
242# a (trivial) index.html. Change the definition of $ICONSERVER in
243# .latex2html-init to use a different location for the icons directory.
Guido van Rossume83e3801995-03-17 16:01:35 +0000244
Guido van Rossum9cb64801997-12-29 20:01:55 +0000245# The sed hack rips out a superfluous comma which I haven't found the
246# source of. The prominent location makes it worth the extra step;
247# this affects the title pages!
Fred Drakefc8f6f31996-12-06 18:45:30 +0000248
Fred Drakeddae4141998-02-17 15:45:25 +0000249l2h: l2hapi l2hext l2hlib l2htut
Guido van Rossum6938f061994-08-01 12:22:53 +0000250
Fred Drakeb4d4e251996-11-11 21:03:01 +0000251l2htut: tut.dvi myformat.perl
Guido van Rossum6938f061994-08-01 12:22:53 +0000252 $(L2H) $(L2HARGS) tut.tex
Fred Drakefc8f6f31996-12-06 18:45:30 +0000253 sed 's/^<P CLASS=ABSTRACT>,/<P CLASS=ABSTRACT>/' \
254 <tut/tut.html >tut/xxx
255 mv tut/xxx tut/tut.html
Fred Drake03ff6f71997-08-22 18:18:54 +0000256 ln -s tut.html tut/index.html || true
Guido van Rossum6938f061994-08-01 12:22:53 +0000257
Fred Drakeb4d4e251996-11-11 21:03:01 +0000258l2hext: ext.dvi myformat.perl
Guido van Rossum6938f061994-08-01 12:22:53 +0000259 $(L2H) $(L2HARGS) ext.tex
Fred Drakefc8f6f31996-12-06 18:45:30 +0000260 sed 's/^<P CLASS=ABSTRACT>,/<P CLASS=ABSTRACT>/' \
261 <ext/ext.html >ext/xxx
262 mv ext/xxx ext/ext.html
Fred Drake03ff6f71997-08-22 18:18:54 +0000263 ln -s ext.html ext/index.html || true
Guido van Rossum970871f1993-02-21 20:10:26 +0000264
Fred Drakeb4d4e251996-11-11 21:03:01 +0000265l2hlib: lib.dvi myformat.perl
Fred Drake03ff6f71997-08-22 18:18:54 +0000266 ./fix_libaux.sed <lib.aux >lib1.aux
267 mv lib1.aux lib.aux
Fred Drakedd946761998-02-18 16:02:14 +0000268 if [ -d lib ] ; then rm -f lib/*.html ; fi
Guido van Rossume83e3801995-03-17 16:01:35 +0000269 $(L2H) $(L2HARGS) lib.tex
Fred Drakedd946761998-02-18 16:02:14 +0000270 (cd lib; ../node2label.pl footnode.html lib.html node*.html)
Fred Drakef1e67071996-12-06 15:11:34 +0000271 sed 's/^<P CLASS=ABSTRACT>,/<P CLASS=ABSTRACT>/' \
272 <lib/lib.html >lib/xxx
273 mv lib/xxx lib/lib.html
Fred Drake03ff6f71997-08-22 18:18:54 +0000274 ln -s lib.html lib/index.html || true
Guido van Rossume83e3801995-03-17 16:01:35 +0000275
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000276l2hapi: api.dvi myformat.perl
277 $(L2H) $(L2HARGS) api.tex
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000278 sed 's/^<P CLASS=ABSTRACT>,/<P CLASS=ABSTRACT>/' \
279 <api/api.html >api/xxx
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000280 mv api/xxx api/api.html
Fred Drake03ff6f71997-08-22 18:18:54 +0000281 ln -s api.html api/index.html || true
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000282
Fred Drake04cf4dc1998-02-12 22:33:50 +0000283pdf-$(VERSION).tar.gz: $(PDFFILES)
284 tar cf - ???.pdf | gzip -9 >pdf-$(VERSION).tar.gz
285
286postscript-$(VERSION).tar.gz: $(PSFILES) ref/ref.ps
287 cp ref/ref.ps .
288 tar cf - ???.ps | gzip -9 >postscript-$(VERSION).tar.gz
289 rm ref.ps
290
Guido van Rossum330c6601997-11-26 15:31:32 +0000291tarhtml:
Guido van Rossum84cca441997-11-25 20:49:09 +0000292 @echo "Did you remember to run makeMIFs.py in the ref subdirectory...?"
Fred Drake33d05b91998-01-13 16:33:09 +0000293 tar cf - index.html ???/???.css ???/*.html lib/*.gif icons/*.* \
Fred Drake95810e41998-01-13 17:18:57 +0000294 | gzip -9 >html-$(VERSION).tar.gz
Fred Drake33d05b91998-01-13 16:33:09 +0000295
Fred Drake04cf4dc1998-02-12 22:33:50 +0000296tarps: postscript-$(VERSION).tar.gz
Fred Drake33d05b91998-01-13 16:33:09 +0000297
Fred Drake04cf4dc1998-02-12 22:33:50 +0000298tarpdf: pdf-$(VERSION).tar.gz
299
300tarballs: tarpdf tarps tarhtml
Guido van Rossum84cca441997-11-25 20:49:09 +0000301
Guido van Rossume83e3801995-03-17 16:01:35 +0000302
303# Housekeeping targets
304
Guido van Rossum9231c8f1997-05-15 21:43:21 +0000305# Remove temporary files; all except the following:
306# - sources: .tex, .bib, .sty
Fred Drake04cf4dc1998-02-12 22:33:50 +0000307# - useful results: .dvi, .pdf, .ps, .texi, .info
Fred Drake03ff6f71997-08-22 18:18:54 +0000308clean: l2hclean
Fred Drake6eab2fb1998-02-13 03:23:33 +0000309 rm -f @* *~ *.aux *.idx *.ilg *.ind *.log *.toc *.blg *.bbl *.py[co]
Fred Drake04cf4dc1998-02-12 22:33:50 +0000310 rm -f *.bak *.orig lib1.texi
Fred Drake95810e41998-01-13 17:18:57 +0000311 rm -f html-$(VERSION).tar.gz postscript-$(VERSION).tar.gz
Fred Drake04cf4dc1998-02-12 22:33:50 +0000312 rm -f pdf-$(VERSION).tar.gz
Guido van Rossum5b343731992-07-07 09:06:34 +0000313
Fred Drake03ff6f71997-08-22 18:18:54 +0000314l2hclean:
Fred Drake5de31fc1997-08-22 18:20:33 +0000315 rm -rf api ext lib tut
Fred Drake03ff6f71997-08-22 18:18:54 +0000316
Guido van Rossume83e3801995-03-17 16:01:35 +0000317# Remove temporaries as well as final products
Guido van Rossum5b343731992-07-07 09:06:34 +0000318clobber: clean
Fred Drake6b7fc6f1998-02-04 20:33:13 +0000319 rm -f *.dvi *.pdf *.ps *.texi *.info *.info-[0-9]*