1 # Make file for Exim documentation from xfpt source.
3 notarget:; @echo "** You must specify a target, in the form x.y, where x is 'filter', 'spec',"
4 @echo "** or 'test', and y is 'xml', 'fo', 'ps', 'pdf', 'html', 'txt', or 'info'."
5 @echo "** One other possible target is 'exim.8'".
9 ############################# EVERYTHING ###############################
11 # Generate all the documentation files...
13 ## removed info files as I cannot generate them - spec.info filter.info
14 ## removed html files as superceded by new website code
15 everything: spec.pdf spec.ps spec.txt \
16 filter.pdf filter.ps filter.txt \
19 ############################## MAN PAGE ################################
21 exim.8: spec.xml x2man
24 ########################################################################
28 echo .macro version > $@
29 echo $(EXIM_VER) >> $@
31 echo .macro fulldate >> $@
32 date "+%d %b %Y" >> $@
34 echo .macro year >> $@
39 ############################### FILTER #################################
41 filter.xml: local_params filter.xfpt
44 filter-pr.xml: filter.xml Pre-xml
45 ./Pre-xml -bookinfo <filter.xml >filter-pr.xml
47 filter-txt.xml: filter.xml Pre-xml
48 ./Pre-xml -ascii -html -quoteliteral <filter.xml >filter-txt.xml
50 filter-info.xml: filter.xml Pre-xml
51 ./Pre-xml -ascii -html <filter.xml >filter-info.xml
53 filter.fo: filter-pr.xml MyStyle-filter-fo.xsl MyStyle-fo.xsl MyStyle.xsl
54 /bin/rm -rf filter.fo filter-pr.fo
55 xmlto -x MyStyle-filter-fo.xsl fo filter-pr.xml
56 /bin/mv -f filter-pr.fo filter.fo
58 # Do not use pdf2ps from the PDF version; better PS is generated directly.
61 ### PS/PDF generation using fop
64 fop-filter.ps: filter.fo
65 fop filter.fo -ps filter-tmp.ps
66 mv filter-tmp.ps filter.ps
68 # Do not use ps2pdf from the PS version; better PDF is generated directly. It
69 # contains cross links etc.
71 fop-filter.pdf: filter.fo PageLabelPDF
72 fop filter.fo -pdf filter-tmp.pdf
73 ./PageLabelPDF 2 <filter-tmp.pdf >filter.pdf
76 ### PS/PDF generation using SDoP
79 sdop-filter.ps: filter-pr.xml
80 sdop -o filter.ps filter-pr.xml
82 sdop-filter.pdf: filter.ps
83 ps2pdf filter.ps filter.pdf
86 ### PS/PDF default setting
89 filter.ps: sdop-filter.ps
91 filter.pdf: sdop-filter.pdf
96 filter.txt: filter-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
98 /bin/rm -rf filter-txt.html
99 xmlto -x MyStyle-txt-html.xsl html-nochunks filter-txt.xml
100 w3m -dump filter-txt.html | ./Tidytxt >filter.txt
101 ./SanityTestText filter.txt
103 # I have not found a way of making docbook2texi write its output anywhere
104 # other than the file name that it makes up. The --to-stdout option does not
107 filter.info: filter-info.xml
108 docbook2texi filter-info.xml
109 perl -ne 's/conceptindex/cindex/;s/optionindex/findex/;print;' \
110 <exim_filtering.texi | ./Tidytxt >filter.texinfo
111 /bin/rm -rf exim_filtering.texi
112 makeinfo -o filter.info filter.texinfo
114 ########################################################################
117 ################################ SPEC ##################################
119 spec.xml: local_params spec.xfpt
122 spec-pr.xml: spec.xml Pre-xml
123 ./Pre-xml -optbreak <spec.xml >spec-pr.xml
125 spec-txt.xml: spec.xml Pre-xml
126 ./Pre-xml -ascii -html -noindex -quoteliteral \
127 <spec.xml >spec-txt.xml
129 spec-info.xml: spec.xml Pre-xml
130 ./Pre-xml -ascii -html -noindex <spec.xml >spec-info.xml
132 spec.fo: spec-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \
134 /bin/rm -rf spec.fo spec-pr.fo
135 xmlto -x MyStyle-spec-fo.xsl fo spec-pr.xml
136 /bin/mv -f spec-pr.fo spec.fo
139 ### PS/PDF generation using fop
142 # Do not use pdf2ps from the PDF version; better PS is generated directly.
145 FOP_OPTS=-Xmx512m fop spec.fo -ps spec-tmp.ps
146 mv spec-tmp.ps spec.ps
148 # Do not use ps2pdf from the PS version; better PDF is generated directly. It
149 # contains cross links etc. We post-process it to add page label information
150 # so that the page identifiers shown by acroread are the correct page numbers.
152 fop-spec.pdf: spec.fo PageLabelPDF
153 FOP_OPTS=-Xmx512m fop spec.fo -pdf spec-tmp.pdf
154 ./PageLabelPDF 12 <spec-tmp.pdf >spec.pdf
157 ### PS/PDF generation using SDoP
160 sdop-spec.ps: spec-pr.xml
161 sdop -o spec.ps spec-pr.xml
163 sdop-spec.pdf: spec.ps
164 ps2pdf spec.ps spec.pdf
167 ### PS/PDF default setting
170 spec.ps: sdop-spec.ps
172 spec.pdf: sdop-spec.pdf
177 spec.txt: spec-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
179 /bin/rm -rf spec-txt.html
180 xmlto -x MyStyle-txt-html.xsl html-nochunks spec-txt.xml
181 w3m -dump spec-txt.html | ./Tidytxt >spec.txt
182 ./SanityTestText spec.txt
184 # I have not found a way of making docbook2texi write its output anywhere
185 # other than the file name that it makes up. The --to-stdout option does not
188 spec.info: spec-info.xml
189 docbook2texi spec-info.xml
190 ./TidyInfo <the_exim_mta.texi >spec.texinfo
191 /bin/rm -rf the_exim_mta.texi
192 makeinfo -o spec.info --no-split spec.texinfo
194 ########################################################################
197 ################################ TEST ##################################
199 # These targets (similar to the above) are for running little tests.
204 test-pr.xml: test.xml Pre-xml
205 ./Pre-xml <test.xml >test-pr.xml
207 test-html.xml: test.xml Pre-xml
208 ./Pre-xml -html -oneindex <test.xml >test-html.xml
210 test-txt.xml: test.xml Pre-xml
211 ./Pre-xml -ascii -html -noindex -quoteinfo \
212 <test.xml >test-txt.xml
214 test-info.xml: test.xml Pre-xml
215 ./Pre-xml -ascii -html -noindex <test.xml >test-info.xml
217 test.fo: test-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \
219 /bin/rm -rf test.fo test-pr.fo
220 xmlto -x MyStyle-spec-fo.xsl fo test-pr.xml
221 /bin/mv -f test-pr.fo test.fo
224 ### PS/PDF generation using fop
227 # Do not use pdf2ps from the PDF version; better PS is generated directly.
230 fop test.fo -ps test-tmp.ps
231 mv test-tmp.ps test.ps
233 # Do not use ps2pdf from the PS version; better PDF is generated directly. It
234 # contains cross links etc.
236 fop-test.pdf: test.fo
237 fop test.fo -pdf test-tmp.pdf
238 mv test-tmp.pdf test.pdf
241 ### PS/PDF generation using SDoP
244 sdop-test.ps: test-pr.xml
245 sdop -o test.ps test-pr.xml
247 sdop-test.pdf: test.ps
248 ps2pdf test.ps test.pdf
251 ### PS/PDF default setting
254 test.ps: sdop-test.ps
256 test.pdf: sdop-test.pdf
262 test.txt: test-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
264 /bin/rm -rf test-txt.html
265 xmlto -x MyStyle-txt-html.xsl html-nochunks test-txt.xml
266 w3m -dump test-txt.html | Tidytxt >test.txt
268 # I have not found a way of making docbook2texi write its output anywhere
269 # other than the file name that it makes up. The --to-stdout option does not
272 test.info: test-info.xml
273 docbook2texi test-info.xml
274 ./TidyInfo <short_title.texi >test.texinfo
275 /bin/rm -rf short_title.texi
276 makeinfo -o test.info test.texinfo
278 ########################################################################
281 ############################## OS FIXUP ################################
283 # Yes, we've advanced so far in text processing that we now have to
284 # hardcode in complete paths and so become dependent upon exactly where
285 # files were installed for xsl:import. Which of course varies by OS.
290 ########################################################################
293 ################################ CLEAN #################################
295 clean:; /bin/rm -rf exim.8 \
296 filter*.xml spec*.xml test*.xml \
298 filter*.html spec*.html test*.html \
299 filter*.txt spec*.txt test*.txt \
300 *.info* *.texinfo *.texi
302 ########################################################################