# Makefile for the Coq documentation # if coqc,coqtop,coq-tex are not in your PATH, you need the environment # variable COQBIN to be correctly set # (COQTOP is autodetected) # (some files are preprocessed using Coq and some part of the documentation # is automatically built from the theories sources) # To compile documentation, you need the following tools: # Dvi: latex (latex2e), bibtex, makeindex, dviselect (package RPM dviutils) # Ps: dvips, psutils (ftp://ftp.dcs.ed.ac.uk/pub/ajcd/psutils.tar.gz) # Pdf: pdflatex # Html: # - hevea: http://para.inria.fr/~maranget/hevea/ # - htmlSplit: http://coq.inria.fr/~delahaye # Rapports INRIA: dviselect, rrkit (par Michel Mauny) ifeq ("$(COQBIN)","") COQBINPATH = else COQBINPATH = $(COQBIN)/ endif DOCCOQTOP=$(COQBINPATH)coqtop #.byte DOCCOQC=$(COQBINPATH)coqc COQTOP=`$(DOCCOQC) -where` COQTEX=$(COQBINPATH)coq-tex -n 72 -image $(DOCCOQTOP) -v -sl -small #COQWEBSTY=$(HOME)/lib/tex/ COQWEBSTY=/usr/share/texmf/tex/latex/misc/ HEVEALIB=/usr/local/lib/hevea:/usr/lib/hevea LATEX=latex BIBTEX=bibtex -min-crossrefs=10 MAKEINDEX=makeindex PDFLATEX=pdflatex MKDIR=mkdir TEST=test TEXINPUTS=/usr/local/lib/rrkit/RRINPUTSDIR:$(COQWEBSTY):$(HEVEALIB):.: INPUTS=./version.tex ./macros.tex ./title.tex ./headers.tex ./Reference-Manual.tex LIBFILES=library/Logic.tex library/Datatypes.tex library/Peano.tex \ library/Wf.tex library/Specif.tex REFMANCOQTEXFILES=\ RefMan-gal.v.tex RefMan-ext.v.tex RefMan-mod.v.tex RefMan-tac.v.tex \ RefMan-cic.v.tex RefMan-lib.v.tex RefMan-tacex.v.tex \ RefMan-syn.v.tex RefMan-oth.v.tex COQTEXFILES= Cases.v.tex Coercion.v.tex Extraction.v.tex \ Omega.v.tex Changes.v.tex Tutorial.v.tex Polynom.v.tex \ Setoid.v.tex #SUPPRIME: Program.v.tex Natural.v.tex Correctness.v.tex REFMANFILES= Reference-Manual.tex RefMan-pre.tex RefMan-int.tex \ RefMan-pro.tex RefMan-com.tex RefMan-ltac.tex RefMan-uti.tex \ RefMan-ide.tex coqide.eps coqide-queries.eps RefMan-add.tex RefMan-modr.tex \ $(REFMANCOQTEXFILES) REFMAN=Reference-Manual VERSION=8.0 #VERSION=POSITIONNEZ-CETTE-VARIABLE FTPDOCDIR=/net/pauillac/infosystems/ftp/coq/coq/V$(VERSION)/doc WWWDOCDIR=/net/pauillac/infosystems/www/coq/doc FTPDOCS=Reference-Manual-base.ps.gz Reference-Manual-base.dvi.gz \ Reference-Manual-addendum.ps.gz Reference-Manual-addendum.dvi.gz\ Reference-Manual-all.ps.gz Reference-Manual-all.dvi.gz\ # Library.dvi.gz Library.ps.gz\ Tutorial.dvi.gz Tutorial.ps.gz\ README all-ps-docs.tar.gz\ # Changes.dvi.gz Changes.ps.gz FTPHTMLDOCS=doc-html.tar.gz ######################### # Principal targets ######################## all: check-env all-ps all-pdf check-env: @if $(TEST) "$(COQBIN)" = ""; then \ if coq-tex; then true ; \ else echo "coq-tex not found, COQBIN undefined"; exit 1; fi; \ fi @if $(TEST) "$(COQTOP)" = ""; then echo "COQTOP undefined"; exit 1; \ else echo "COQTOP = $(COQTOP)"; fi coq-part: $(REFMANCOQTEXFILES) $(COQTEXFILES) demos-programs library/libdoc.tex latex-part: all-dvi all-dvi: Tutorial.v.dvi Reference-Manual.dvi # faq.v.dvi Library.dvi Changes.v.dvi all-pdf: Tutorial.v.pdf Reference-Manual.pdf # faq.v.pdf Library.pdf Changes.v.pdf all-ps: Tutorial.v.ps Reference-Manual.ps # faq.v.ps Library.ps Changes.v.ps all-html: Tutorial.v.html Reference-Manual.html # faq.v.html Library.html Changes.v.html #version version.tex: Makefile echo "\newcommand{\coqversion}{$(VERSION)}" > version.tex # dvips et dviselect existent sur loupiac distrib: make check-env make clean-coq demos-programs make clean-latex all-dvi all-ps all-pdf compress-latex make clean-html all-html doc-html.tar.gz html-www compress-latex: sh Reference-Manual.sh mv -f Reference-Manual.ps Reference-Manual-all.ps mv -f Tutorial.v.ps Tutorial.ps mv -f Tutorial.v.dvi Tutorial.dvi mv -f Reference-Manual.dvi Reference-Manual-all.dvi # mv -f Changes.v.ps Changes.ps # mv -f Changes.v.dvi Changes.dvi - mv -f Tutorial.v.pdf Tutorial.pdf # - mv -f Changes.v.pdf Changes.pdf tar cf all-ps-docs.tar Reference-Manual-base.ps \ Reference-Manual-addendum.ps Tutorial.ps # Library.ps # Changes.ps gzip -f *.ps gzip -f *.dvi gzip -f *.pdf gzip -f all-ps-docs.tar Tutorial.v.html: Tutorial.v.tex hevea ./book-html.sty ./coq-html.sty ./Tutorial.v Changes.v.html: Changes.v.tex hevea ./Changes.v.tex Reference-Manual.html: $(INPUTS) $(REFMANFILES) $(COQTEXFILES) biblio.bib #1.05 ? hevea -fix ./book-html.sty ./coq-html.sty ./Reference-Manual.tex #1.04 hevea ./book-html.sty ./coq-html.sty ./Reference-Manual.tex hevea -fix -nosymb -exec xxdate.exe ./Reference-Manual.tex faq.v.html: faq.v.tex hevea ./faq.v coq.info: $(INPUTS) $(REFMANFILES) $(COQTEXFILES) biblio.bib hevea -info ./book-html.sty ./coq-html.sty ./Reference-Manual.tex doc-html.tar.gz: all-html $(MKDIR) -p coq-docs-html rm -rf coq-docs-html/* cp Tutorial.v.html coq-docs-html/tutorial.html cp Reference-Manual.html coqide-queries.png coqide.png coq-docs-html (cd coq-docs-html; hacha -o toc.html ./Reference-Manual.html; rm ./Reference-Manual.html) cp cover.html main.html main-0.html coq-docs-html tar cf doc-html.tar coq-docs-html gzip -f doc-html.tar # Pour le site de Coq. html-www: all-html $(MKDIR) -p www rm -rf www/* cp Tutorial.v.html www/tutorial.html cp coqide-queries.png coqide.png www (cd www; hacha -o toc.html ../Reference-Manual.html) cp cover.html main.html main-0.html www clean-refman: rm -f Reference-Manual.toc Reference-Manual.idx Reference-Manual.atoc\ Reference-Manual.aux Reference-Manual.bbl Reference-Manual.blg\ Reference-Manual.ilg Reference-Manual.ind\ Reference-Manual.tacidx Reference-Manual.tacind\ Reference-Manual.comidx Reference-Manual.comind\ Reference-Manual.erridx Reference-Manual.errind\ Reference-Manual.dvi Reference-Manual.ps\ Reference-Manual.sh\ $(REFMANFILES:.tex=.aux) $(REFMANFILES:.tex=.log)\ $(COQTEXFILES:.tex=.aux) $(COQTEXFILES:.tex=.log) clean-latex: clean-refman rm -f *.dvi *.aux *.log *.bbl *.blg *.ps *.toc *.idx *~ *.ilg *.ind\ *.dvi.gz *.ps.gz *.pdf *.pdf.gz clean-coq: rm -f *.v.tex avl.ml heapsort.ml euclid.ml library/libdoc.tex *.cm[io] clean: clean-coq clean-latex clean-html: rm -f Tutorial.v.html Reference-Manual.html # Changes.v.html rm -f *.hatoc *.haux *.hcomind *.herrind *.hidx *.hind *.htacind *.htoc cleanall: clean clean-html ######################### # Implicit rules ######################### .SUFFIXES: .dvi .tex .v.tex .ps .pdf .eps .png .tex.dvi: $(LATEX) $< $(LATEX) $< .tex.pdf: $(PDFLATEX) $< $(PDFLATEX) $< .tex.v.tex: $(COQTEX) $< .dvi.ps: dvips -o $@ $< %.eps: %.png pngtopnm $< | pnmtops -equalpixels -noturn -rle > $@ ########################## # Dependencies ########################## Library.dvi: $(INPUTS) library.coqweb.tex Library.tex $(LATEX) Library $(LATEX) Library Library.pdf: $(INPUTS) library.coqweb.tex Library.tex $(PDFLATEX) Library $(PDFLATEX) Library # L'option -exec xxdate.exe sert a produire la date (macro \today) # mais ne marche pas avec hevea 1.04 Library.html: $(INPUTS) library.coqweb.tex Library.tex hevea ./coq-html.sty -exec xxdate.exe $(COQWEBSTY)/coqweb.sty ./Library.tex #1.04 hevea ./coq-html.sty $(COQWEBSTY)/coqweb.sty ./Library.tex LIBDIRS= Logic Bool Arith ZArith Reals Lists Sets Relations \ Wellfounded IntMap library.coqweb.tex: library.files WHERE=`pwd` ; \ cd $(COQTOP)/theories; \ coqweb --noweb -o $$WHERE/$@ --no-preamble `cat $$WHERE/library.files` GALLINA=$(COQBINPATH)gallina # On garde la liste de tous les *.v avec dates dans library.files.ls # Si elle a change depuis la derniere fois ou library.files n'existe pas # on fabrique des .g (si besoin) et la liste library.files dans # l'ordre de ls -tr des *.vo # Ce dernier trie les fichiers dans l'ordre inverse de leur date de création # En supposant que make fait son boulot, ca fait un tri topologique du # graphe des dépendances library.files:: rm -f library.files.ls.tmp (cd $(COQTOP)/theories ; find $(LIBDIRS) -name "*.v" -ls) > library.files.ls.tmp if ! test -e library.files || ! cmp library.files.ls library.files.ls.tmp; then \ mv -f library.files.ls.tmp library.files.ls; \ rm -f library.files; touch library.files; \ ABSOLUTE=`pwd`/library.files ; \ for rep in $(LIBDIRS) ; do \ (cd $(COQTOP)/theories/$$rep ; \ echo $$rep/intro.tex >> $$ABSOLUTE ; \ VOFILES=`ls -tr *.vo` ; \ for file in $$VOFILES ; do \ VF=`basename $$file \.vo` ; \ if $(TEST) \( ! -e $$VF.g \) -o \( $$VF.v -nt $$VF.g \) ; then \ $(GALLINA) $$VF.v; fi ; \ echo $$rep/$$VF.g >> $$ABSOLUTE ; \ done \ ) ; \ done ; \ fi demos-programs: # (cd ../theories/DEMOS/PROGRAMS ; make all) Recursive-Definition.v.tex: ./title.tex Recursive-Definition.tex Tutorial.v.dvi: ./version.tex ./title.tex Tutorial.v.tex Tutorial.v.pdf: ./version.tex ./title.tex Tutorial.v.tex # RefMan-ppr.v.tex: ../tactics/eqdecide.cmo # RefMan-tus.v.tex: ../tactics/EqDecide.vo ../tactics/eqdecide.cmo Reference-Manual.ps: Reference-Manual.dvi # The second LATEX compilation is necessary otherwise the pages of the index # are not correct (don't know why...) - BB Reference-Manual.dvi: $(INPUTS) $(REFMANFILES) $(COQTEXFILES) biblio.bib $(LATEX) Reference-Manual $(BIBTEX) Reference-Manual $(LATEX) Reference-Manual $(MAKEINDEX) Reference-Manual $(MAKEINDEX) Reference-Manual.tacidx -o Reference-Manual.tacind $(MAKEINDEX) Reference-Manual.comidx -o Reference-Manual.comind $(MAKEINDEX) Reference-Manual.erridx -o Reference-Manual.errind $(LATEX) Reference-Manual Reference-Manual.pdf: Reference-Manual.dvi #rm -f Reference-Manual.sh $(PDFLATEX) Reference-Manual.tex quick: $(INPUTS) $(REFMANFILES) $(COQTEXFILES) biblio.bib #rm -f Reference-Manual.sh $(LATEX) Reference-Manual ################### # RT ################### # Fabrication d'un RT INRIA (utilise rrkit de Michel Mauny) Reference-Manual-RT.dvi: Reference-Manual.dvi RefMan-cover.tex dviselect -i Reference-Manual.dvi -o RefMan-body.dvi 3: $(LATEX) RefMan-cover.tex set a=`tail -1 Reference-Manual.log`;\ set a=expr \("$$a" : '.*(\(.*\) pages.*'\) % 2;\ if $(TEST) "$$a = 0";\ then rrkit RefMan-cover.dvi RefMan-body.dvi Reference-Manual-RT.dvi;\ else rrkit -odd RefMan-cover.dvi RefMan-body.dvi Reference-Manual-RT.dvi;\ fi # Fabrication d'un RT INRIA (utilise rrkit de Michel Mauny) Tutorial-RT.dvi : Tutorial.v.dvi Tutorial-cover.tex dviselect -i Tutorial.v.dvi -o Tutorial-body.dvi 3: $(LATEX) Tutorial-cover.tex set a=`tail -1 Tutorial.v.log`;\ set a=expr \("$$a" : '.*(\(.*\) pages.*'\) % 2;\ if $(TEST) "$$a = 0";\ then rrkit Tutorial-cover.dvi Tutorial-body.dvi Tutorial-RT.dvi;\ else rrkit -odd Tutorial-cover.dvi Tutorial-body.dvi Tutorial-RT.dvi;\ fi ################ doc ftp and www installation ############ doc-ftp-www-install: doc-ftp-install doc-www-install doc-ftp-install: - mkdir $(FTPDOCDIR) cp $(FTPDOCS) $(FTPHTMLDOCS) $(FTPDOCDIR) - chmod g+w $(FTPDOCDIR)/* faq-www-install: cp faq.v.html $(WWWDOCDIR)/faq.html doc-www-install: (cd $(WWWDOCDIR); rm -f node*.html main*.html toc.html \ tutorial.html changes.html cover.html) cp www/* $(WWWDOCDIR) # traducteur V7 -> V8 tradv8: tradv8.ml4 ocamlopt.opt -o $@ str.cmxa unix.cmxa -pp "camlp4o -impl" -impl $^ v8: tradv8 for f in `grep -l coq_exa *tex`; do \ echo $$f; \ ./tradv8 $$f; mv $$f $$f.save; mv $$f.v8 $$f; \ done