summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Doc/Makefile104
1 files changed, 52 insertions, 52 deletions
diff --git a/Doc/Makefile b/Doc/Makefile
index f71aed6..ea094ca 100644
--- a/Doc/Makefile
+++ b/Doc/Makefile
@@ -46,28 +46,27 @@
# Customizations -- you *may* have to edit these
# Where are the various programs?
-LATEX= latex
-PDFLATEX= pdflatex
-BIBTEX= bibtex
+LATEX= TEXINPUTS=$(TEXINPUTS) latex
+PDFLATEX= TEXINPUTS=$(TEXINPUTS) pdflatex
+TEXINPUTS= texinputs:
DVIPS= dvips -f -N0
DISTILL= distill
MAKEINDEX= makeindex
-L2H= latex2html
+L2H= TEXINPUTS=$(TEXINPUTS) latex2html -init_file perl/l2hinit.perl
L2HARGS= -address $$LOGNAME@`domainname`
+WEBCHECKER= $(PYTHON) ../Tools/webchecker/webchecker.py
# Install destination -- not used now but might be useful some time...
DESTDIR= /usr/local
LIBDESTDIR= $DESTDIR/lib
-LIBDEST= $LIBDESTDIR/python
+LIBDEST= $LIBDESTDIR/python$(VERSION)
DOCDESTDIR= $LIBDEST/doc
# This is only used for .info generation:
EMACS= emacs
PYTHON= python
MAKEINFO= makeinfo
-# When debugging partparse.py, make this the pyc file:
-PARTPARSEOBJ= partparse.pyc
-PARTPARSE= $(PYTHON) $(PARTPARSEOBJ)
+PARTPARSE= $(PYTHON) tools/partparse.py
# Ideally, you shouldn't need to edit beyond this point
@@ -78,9 +77,13 @@ INFOFILES= python-lib.info
PDFFILES= api.pdf ext.pdf lib.pdf tut.pdf
PSFILES= api.ps ext.ps lib.ps tut.ps
+MANSTYLES=texinputs/fncychap.sty texinputs/manual.cls texinputs/python.sty
+
# Main target
all: all-ps
+world: all-ps all-pdf l2h lib.info tarballs
+
all-dvi: $(DVIFILES)
all-pdf: $(PDFFILES)
all-ps: $(PSFILES)
@@ -121,13 +124,15 @@ tut-all: tut.dvi tut.pdf tut.ps l2htut
# This rule avoids creation of the intermediate PostScript files and uses
# only free software.
#
-.dvi.pdf:
+.dvi.pdf: $*.bkm
+ $(PYTHON) tools/toc2bkm.py $*
$(PDFLATEX) $*
# Dependencies
-COMMONTEX=python.sty manual.cls copyright.tex boilerplate.tex
+COMMONTEX=$(MANSTYLES) copyright.tex boilerplate.tex
+COMMONPERL=perl/manual.perl perl/python.perl
-$(DVIFILES): fix_hack $(COMMONTEX)
+$(DVIFILES): tools/fix_hack $(COMMONTEX)
# LaTeX source files for the Python Library Reference
LIBFILES = lib.tex \
@@ -163,14 +168,14 @@ LIBFILES = lib.tex \
libframework.tex libminiae.tex libbinhex.tex libuu.tex libsunaudio.tex
# Library document
-lib.dvi: modindex.py indfix.py $(LIBFILES)
- ./newind.py >$*.ind
- ./newind.py modindex >mod$*.ind
+lib.dvi: tools/modindex.py tools/indfix.py $(LIBFILES)
+ tools/newind.py >$*.ind
+ tools/newind.py modindex >mod$*.ind
$(LATEX) $*
- ./modindex.py mod$*.idx
- ./fix_hack $*.idx
+ tools/modindex.py mod$*.idx
+ tools/fix_hack $*.idx
$(MAKEINDEX) $*.idx
- ./indfix.py $*.ind
+ tools/indfix.py $*.ind
$(LATEX) $*
# Tutorial document
@@ -181,9 +186,9 @@ tut.dvi: tut.tex
# Extending & Embedding, Python/C API documents.
# Done this way to avoid repeated command sets.
.tex.dvi:
- ./newind.py >$*.ind
+ tools/newind.py >$*.ind
$(LATEX) $*
- ./fix_hack $*.idx
+ tools/fix_hack $*.idx
$(MAKEINDEX) $*.idx
$(LATEX) $*
@@ -191,14 +196,6 @@ tut.dvi: tut.tex
# The remaining part of the Makefile is concerned with various
# conversions, as described above. See also the README file.
-.SUFFIXES: .py .pyc .pyo
-
-.py.pyo:
- $(PYTHON) -O -c "import $*"
-
-.py.pyc:
- $(PYTHON) -c "import $*"
-
.PRECIOUS: python-lib.texi
# The sed script in this target fixes a really nasty little condition in
@@ -207,13 +204,13 @@ tut.dvi: tut.tex
# least the info file gets generated.
lib1.texi: $(LIBFILES) texipre.dat texipost.dat $(PARTPARSEOBJ)
- $(PARTPARSE) -o $@ `./whichlibs`
+ $(PARTPARSE) -o $@ `tools/whichlibs`
sed 's/"{\\}n{\\}n/"\\n\\n/' $@ >temp.texi
mv temp.texi $@
-python-lib.texi: lib1.texi fix.el
+python-lib.texi: lib1.texi tools/fix.el
cp lib1.texi temp.texi
- $(EMACS) -batch -l fix.el -f save-buffer -kill
+ $(EMACS) -batch -l tools/fix.el -f save-buffer -kill
mv temp.texi $@
python-lib.info: python-lib.texi
@@ -241,40 +238,43 @@ lib.texi: python-lib.texi
l2h: l2hapi l2hext l2hlib l2htut
-l2htut: tut.dvi manual.perl python.perl
+l2htut: tut.dvi $(COMMONPERL)
$(L2H) $(L2HARGS) tut.tex
- (cd tut; ../node2label.pl *.html)
- ln -s tut.html tut/index.html || true
+ (cd tut; ../tools/node2label.pl *.html)
-l2hext: ext.dvi manual.perl python.perl
+l2hext: ext.dvi $(COMMONPERL)
$(L2H) $(L2HARGS) ext.tex
- (cd ext; ../node2label.pl *.html)
- ln -s ext.html ext/index.html || true
+ (cd ext; ../tools/node2label.pl *.html)
-l2hlib: lib.dvi manual.perl python.perl
- ./fix_libaux.sed <lib.aux >lib1.aux
+l2hlib: lib.dvi $(COMMONPERL)
+ tools/fix_libaux.sed <lib.aux >lib1.aux
mv lib1.aux lib.aux
- if [ -d lib ] ; then rm -f lib/*.html ; fi
+ if test -d lib ; then rm -f lib/*.html ; fi
$(L2H) $(L2HARGS) lib.tex
- (cd lib; ../node2label.pl *.html)
- ln -s lib.html lib/index.html || true
+ (cd lib; ../tools/node2label.pl *.html)
-l2hapi: api.dvi manual.perl python.perl
+l2hapi: api.dvi $(COMMONPERL)
$(L2H) $(L2HARGS) api.tex
- (cd api; ../node2label.pl *.html)
- ln -s api.html api/index.html || true
+ (cd api; ../tools/node2label.pl *.html)
+
+# webchecker needs an extra flag to process the huge index from the libref
+webcheck:
+ $(WEBCHECKER) file:`pwd`/api/
+ $(WEBCHECKER) file:`pwd`/ext/
+ $(WEBCHECKER) -m290000 file:`pwd`/lib/
+ $(WEBCHECKER) file:`pwd`/tut/
-info-$(VERSION).tar.gz: $(INFOFILES)
+lib-info-$(VERSION).tar.gz: $(INFOFILES)
tar cf - python-???.info* | gzip -9 >$@
latex-$(VERSION).tar.gz:
- ./mktarball.sh
+ tools/mktarball.sh
# This snags a PDF version if available, but doesn't fail if not.
pdf-$(VERSION).tar.gz: $(PDFFILES)
- if [ -f ref/ref.pdf ] ; then cp ref/ref.pdf . ; else true ; fi
+ if test -f ref/ref.pdf ; then cp ref/ref.pdf . ; else true ; fi
tar cf - ???.pdf | gzip -9 >$@
- if [ -f ref.pdf ] ; then rm ref.pdf ; else true ; fi
+ if test -f ref.pdf ; then rm ref.pdf ; else true ; fi
postscript-$(VERSION).tar.gz: $(PSFILES) ref/ref.ps
cp ref/ref.ps .
@@ -288,7 +288,7 @@ tarhtml:
# convenience targets:
-tarinfo: info-$(VERSION).tar.gz
+tarinfo: lib-info-$(VERSION).tar.gz
tarps: postscript-$(VERSION).tar.gz
@@ -304,7 +304,7 @@ tarballs: tarpdf tarps tarhtml tarinfo tarlatex
# Remove temporary files; all except the following:
# - sources: .tex, .bib, .sty, *.cls
# - useful results: .dvi, .pdf, .ps, .texi, .info
-clean: l2hclean
+clean:
rm -f @* *~ *.aux *.idx *.ilg *.ind *.log *.toc *.blg *.bbl *.py[co]
rm -f *.bak *.orig lib1.texi *.out
rm -f html-$(VERSION).tar.gz info-$(VERSION).tar.gz
@@ -315,8 +315,8 @@ l2hclean:
rm -rf api ext lib tut
# Remove temporaries as well as final products
-clobber: clean
- rm -f *.dvi *.pdf *.ps *.texi *.info *.info-[0-9]*
+clobber: clean l2hclean
+ rm -f *.dvi *.pdf *.ps *.texi python-*.info python-*.info-[0-9]*
realclean: clobber
distclean: clobber