X-Git-Url: https://git.exim.org/users/jgh/exim.git/blobdiff_plain/d1e83bff479907ea191e6e4e0b472edf53c224a3..a466095c0f9c7f48b1c9f857b5a17cab69fecd28:/doc/doc-docbook/Makefile diff --git a/doc/doc-docbook/Makefile b/doc/doc-docbook/Makefile index c2e5593b1..e6f6487d3 100644 --- a/doc/doc-docbook/Makefile +++ b/doc/doc-docbook/Makefile @@ -1,6 +1,6 @@ -# $Cambridge: exim/doc/doc-docbook/Makefile,v 1.3 2005/11/15 16:10:50 ph10 Exp $ +# $Cambridge: exim/doc/doc-docbook/Makefile,v 1.13 2009/10/16 10:36:52 nm4 Exp $ -# Make file for Exim documentation from Asciidoc source. +# Make file for Exim documentation from xfpt source. notarget:; @echo "** You must specify a target, in the form x.y, where x is 'filter', 'spec'," @echo "** or 'test', and y is 'xml', 'fo', 'ps', 'pdf', 'html', 'txt', or 'info'." @@ -8,9 +8,17 @@ notarget:; @echo "** You must specify a target, in the form x.y, where x is ' exit 1 +############################# EVERYTHING ############################### +# +# Generate all the documentation files... +# +everything: spec.pdf spec.ps spec.html spec.info spec.txt \ + filter.pdf filter.ps filter.html filter.info filter.txt \ + exim.8 + ############################## MAN PAGE ################################ -exim.8: spec.xml +exim.8: spec.xml x2man ./x2man ######################################################################## @@ -18,53 +26,85 @@ exim.8: spec.xml ############################### FILTER ################################# -filter.xml: filter.ascd MyAsciidoc.conf - asciidoc -d book -b docbook -f MyAsciidoc.conf filter.ascd +filter.xml: filter.xfpt + xfpt filter.xfpt -filter-fo.xml: filter.xml Pre-xml - Pre-xml -bookinfo filter-fo.xml +filter-pr.xml: filter.xml Pre-xml + ./Pre-xml -bookinfo filter-pr.xml filter-html.xml: filter.xml Pre-xml - Pre-xml -html filter-html.xml + ./Pre-xml -html filter-html.xml + +filter-txt.xml: filter.xml Pre-xml + ./Pre-xml -ascii -html -quoteliteral filter-txt.xml + +filter-info.xml: filter.xml Pre-xml + ./Pre-xml -ascii -html filter-info.xml + +filter.fo: filter-pr.xml MyStyle-filter-fo.xsl MyStyle-fo.xsl MyStyle.xsl + /bin/rm -rf filter.fo filter-pr.fo + xmlto -x MyStyle-filter-fo.xsl fo filter-pr.xml + /bin/mv -f filter-pr.fo filter.fo + +# Do not use pdf2ps from the PDF version; better PS is generated directly. + +### +### PS/PDF generation using fop +### + +fop-filter.ps: filter.fo + fop filter.fo -ps filter-tmp.ps + mv filter-tmp.ps filter.ps + +# Do not use ps2pdf from the PS version; better PDF is generated directly. It +# contains cross links etc. + +fop-filter.pdf: filter.fo PageLabelPDF + fop filter.fo -pdf filter-tmp.pdf + ./PageLabelPDF 2 filter.pdf + +### +### PS/PDF generation using SDoP +### -filter-txt.xml: filter.xml Pre-xml - Pre-xml -ascii -html filter-txt.xml +sdop-filter.ps: filter-pr.xml + sdop -o filter.ps filter-pr.xml -filter.fo: filter-fo.xml MyStyle-filter-fo.xsl MyStyle-fo.xsl MyStyle.xsl - /bin/rm -rf filter.fo filter-fo.fo - xmlto -x MyStyle-filter-fo.xsl fo filter-fo.xml - /bin/mv -f filter-fo.fo filter.fo +sdop-filter.pdf: filter.ps + ps2pdf filter.ps filter.pdf -filter.ps: filter.fo - fop filter.fo -ps filter-tmp.ps - mv filter-tmp.ps filter.ps +### +### PS/PDF default setting +### -#filter.pdf: filter.fo -# fop filter.fo -pdf filter-tmp.pdf -# mv filter-tmp.pdf filter.pdf +filter.ps: sdop-filter.ps -filter.pdf: filter.ps - ps2pdf filter.ps filter.pdf +filter.pdf: sdop-filter.pdf -filter.html: filter-html.xml TidyHTML-filter MyStyle-nochunk-html.xsl MyStyle-html.xsl MyStyle.xsl +### +### + +filter.html: filter-html.xml TidyHTML-filter MyStyle-nochunk-html.xsl \ + MyStyle-html.xsl MyStyle.xsl /bin/rm -rf filter.html filter-html.html xmlto -x MyStyle-nochunk-html.xsl html-nochunks filter-html.xml /bin/mv -f filter-html.html filter.html ./TidyHTML-filter -filter.txt: filter-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl MyStyle.xsl +filter.txt: filter-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \ + MyStyle.xsl /bin/rm -rf filter-txt.html xmlto -x MyStyle-txt-html.xsl html-nochunks filter-txt.xml - w3m -dump filter-txt.html >filter.txt + w3m -dump filter-txt.html | ./Tidytxt >filter.txt # I have not found a way of making docbook2texi write its output anywhere # other than the file name that it makes up. The --to-stdout option does not # work. -filter.info: filter-txt.xml - docbook2texi filter-txt.xml +filter.info: filter-info.xml + docbook2texi filter-info.xml perl -ne 's/conceptindex/cindex/;s/optionindex/findex/;print;' \ - filter.texinfo + filter.texinfo /bin/rm -rf exim_filtering.texi makeinfo -o filter.info filter.texinfo @@ -73,54 +113,89 @@ filter.info: filter-txt.xml ################################ SPEC ################################## -spec.xml: spec.ascd MyAsciidoc.conf - asciidoc -d book -b docbook -f MyAsciidoc.conf spec.ascd +spec.xml: spec.xfpt + xfpt spec.xfpt -spec-fo.xml: spec.xml Pre-xml - Pre-xml spec-fo.xml +spec-pr.xml: spec.xml Pre-xml + ./Pre-xml -optbreak spec-pr.xml spec-html.xml: spec.xml Pre-xml - Pre-xml -abstract -html -oneindex spec-html.xml + ./Pre-xml -html -oneindex \ + spec-html.xml + +spec-txt.xml: spec.xml Pre-xml + ./Pre-xml -ascii -html -noindex -quoteliteral \ + spec-txt.xml + +spec-info.xml: spec.xml Pre-xml + ./Pre-xml -ascii -html -noindex spec-info.xml -spec-txt.xml: spec.xml Pre-xml - Pre-xml -abstract -ascii -html -noindex spec-txt.xml +spec.fo: spec-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \ + MyTitleStyle.xsl + /bin/rm -rf spec.fo spec-pr.fo + xmlto -x MyStyle-spec-fo.xsl fo spec-pr.xml + /bin/mv -f spec-pr.fo spec.fo -spec.fo: spec-fo.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl MyTitleStyle.xsl - /bin/rm -rf spec.fo spec-fo.fo - xmlto -x MyStyle-spec-fo.xsl fo spec-fo.xml - /bin/mv -f spec-fo.fo spec.fo +### +### PS/PDF generation using fop +### -spec.ps: spec.fo +# Do not use pdf2ps from the PDF version; better PS is generated directly. + +fop-spec.ps: spec.fo FOP_OPTS=-Xmx512m fop spec.fo -ps spec-tmp.ps mv spec-tmp.ps spec.ps -#spec.pdf: spec.fo -# FOP_OPTS=-Xmx512m fop spec.fo -pdf spec-tmp.pdf -# mv spec-tmp.pdf spec.pdf +# Do not use ps2pdf from the PS version; better PDF is generated directly. It +# contains cross links etc. We post-process it to add page label information +# so that the page identifiers shown by acroread are the correct page numbers. + +fop-spec.pdf: spec.fo PageLabelPDF + FOP_OPTS=-Xmx512m fop spec.fo -pdf spec-tmp.pdf + ./PageLabelPDF 12 spec.pdf + +### +### PS/PDF generation using SDoP +### + +sdop-spec.ps: spec-pr.xml + sdop -o spec.ps spec-pr.xml + +sdop-spec.pdf: spec.ps + ps2pdf spec.ps spec.pdf + +### +### PS/PDF default setting +### + +spec.ps: sdop-spec.ps -spec.pdf: spec.ps - ps2pdf spec.ps spec.pdf +spec.pdf: sdop-spec.pdf -spec.html: spec-html.xml TidyHTML-spec MyStyle-chunk-html.xsl MyStyle-html.xsl MyStyle.xsl - /bin/rm -rf spec.html - xmlto -x MyStyle-chunk-html.xsl -o spec.html html spec-html.xml +### +### + +spec.html: spec-html.xml TidyHTML-spec MyStyle-chunk-html.xsl \ + MyStyle-html.xsl MyStyle.xsl + /bin/rm -rf spec_html + xmlto -x MyStyle-chunk-html.xsl -o spec_html html spec-html.xml ./TidyHTML-spec -spec.txt: spec-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl MyStyle.xsl +spec.txt: spec-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \ + MyStyle.xsl /bin/rm -rf spec-txt.html xmlto -x MyStyle-txt-html.xsl html-nochunks spec-txt.xml - w3m -dump spec-txt.html | Tidytxt >spec.txt + w3m -dump spec-txt.html | ./Tidytxt >spec.txt # I have not found a way of making docbook2texi write its output anywhere # other than the file name that it makes up. The --to-stdout option does not # work. -spec.info: spec-txt.xml - docbook2texi spec-txt.xml - perl -ne 's/conceptindex/cindex/;s/optionindex/findex/;print;' \ - spec.texinfo +spec.info: spec-info.xml + docbook2texi spec-info.xml + ./TidyInfo spec.texinfo /bin/rm -rf the_exim_mta.texi - makeinfo -o spec.info spec.texinfo + makeinfo -o spec.info --no-split spec.texinfo ######################################################################## @@ -129,40 +204,75 @@ spec.info: spec-txt.xml # These targets (similar to the above) are for running little tests. -test.xml: test.ascd MyAsciidoc.conf - asciidoc -d book -b docbook -f MyAsciidoc.conf test.ascd +test.xml: test.xfpt + xfpt test.xfpt -test-fo.xml: test.xml Pre-xml - ./Pre-xml test-fo.xml +test-pr.xml: test.xml Pre-xml + ./Pre-xml test-pr.xml test-html.xml: test.xml Pre-xml - ./Pre-xml -abstract -html -oneindex test-html.xml + ./Pre-xml -html -oneindex test-html.xml test-txt.xml: test.xml Pre-xml - ./Pre-xml -abstract -ascii -html -noindex test-txt.xml + ./Pre-xml -ascii -html -noindex -quoteinfo \ + test-txt.xml + +test-info.xml: test.xml Pre-xml + ./Pre-xml -ascii -html -noindex test-info.xml + +test.fo: test-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \ + MyTitleStyle.xsl + /bin/rm -rf test.fo test-pr.fo + xmlto -x MyStyle-spec-fo.xsl fo test-pr.xml + /bin/mv -f test-pr.fo test.fo + +### +### PS/PDF generation using fop +### -test.fo: test-fo.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl MyTitleStyle.xsl - /bin/rm -rf test.fo test-fo.fo - xmlto -x MyStyle-spec-fo.xsl fo test-fo.xml - /bin/mv -f test-fo.fo test.fo +# Do not use pdf2ps from the PDF version; better PS is generated directly. -test.ps: test.fo +fop-test.ps: test.fo fop test.fo -ps test-tmp.ps mv test-tmp.ps test.ps -#test.pdf: test.fo -# fop test.fo -pdf test-tmp.pdf -# mv test-tmp.pdf test.pdf +# Do not use ps2pdf from the PS version; better PDF is generated directly. It +# contains cross links etc. + +fop-test.pdf: test.fo + fop test.fo -pdf test-tmp.pdf + mv test-tmp.pdf test.pdf + +### +### PS/PDF generation using SDoP +### + +sdop-test.ps: test-pr.xml + sdop -o test.ps test-pr.xml + +sdop-test.pdf: test.ps + ps2pdf test.ps test.pdf + +### +### PS/PDF default setting +### -test.pdf: test.ps - ps2pdf test.ps test.pdf +test.ps: sdop-test.ps -test.html: test-html.xml MyStyle-nochunk-html.xsl MyStyle-html.xsl MyStyle.xsl +test.pdf: sdop-test.pdf + +### +### + + +test.html: test-html.xml MyStyle-nochunk-html.xsl MyStyle-html.xsl \ + MyStyle.xsl /bin/rm -rf test.html test-html.html xmlto -x MyStyle-nochunk-html.xsl html-nochunks test-html.xml /bin/mv -f test-html.html test.html -test.txt: test-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl MyStyle.xsl +test.txt: test-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \ + MyStyle.xsl /bin/rm -rf test-txt.html xmlto -x MyStyle-txt-html.xsl html-nochunks test-txt.xml w3m -dump test-txt.html | Tidytxt >test.txt @@ -171,16 +281,27 @@ test.txt: test-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl MyStyle # other than the file name that it makes up. The --to-stdout option does not # work. -test.info: test-txt.xml - docbook2texi test-txt.xml - perl -ne 's/conceptindex/cindex/;s/optionindex/findex/;print;' \ - test.texinfo +test.info: test-info.xml + docbook2texi test-info.xml + ./TidyInfo test.texinfo /bin/rm -rf short_title.texi makeinfo -o test.info test.texinfo ######################################################################## +############################## OS FIXUP ################################ + +# Yes, we've advanced so far in text processing that we now have to +# hardcode in complete paths and so become dependent upon exactly where +# files were installed for xsl:import. Which of course varies by OS. + +os-fixup: + ./OS-Fixups + +######################################################################## + + ################################ CLEAN ################################# clean:; /bin/rm -rf exim.8 \