Merge branch 'master' of ssh://git.exim.org/home/git/exim
[exim.git] / doc / doc-docbook / Makefile
CommitLineData
4a04fa7a 1# $Cambridge: exim/doc/doc-docbook/Makefile,v 1.14 2010/05/28 15:38:18 nm4 Exp $
168e428f 2
9b371988 3# Make file for Exim documentation from xfpt source.
168e428f
PH
4
5notarget:; @echo "** You must specify a target, in the form x.y, where x is 'filter', 'spec',"
6 @echo "** or 'test', and y is 'xml', 'fo', 'ps', 'pdf', 'html', 'txt', or 'info'."
7 @echo "** One other possible target is 'exim.8'".
8 exit 1
9
10
207c78ae
NM
11############################# EVERYTHING ###############################
12#
13# Generate all the documentation files...
14#
4a04fa7a 15## removed info files as I cannot generate them - spec.info filter.info
50023e05
NM
16## removed html files as superceded by new website code
17everything: spec.pdf spec.ps spec.txt \
18 filter.pdf filter.ps filter.txt \
207c78ae
NM
19 exim.8
20
168e428f
PH
21############################## MAN PAGE ################################
22
9b371988 23exim.8: spec.xml x2man
168e428f
PH
24 ./x2man
25
26########################################################################
27
28
29############################### FILTER #################################
30
f89d2485
PH
31filter.xml: filter.xfpt
32 xfpt filter.xfpt
168e428f 33
f89d2485
PH
34filter-pr.xml: filter.xml Pre-xml
35 ./Pre-xml -bookinfo <filter.xml >filter-pr.xml
168e428f 36
f89d2485
PH
37filter-txt.xml: filter.xml Pre-xml
38 ./Pre-xml -ascii -html -quoteliteral <filter.xml >filter-txt.xml
9b371988
PH
39
40filter-info.xml: filter.xml Pre-xml
f89d2485 41 ./Pre-xml -ascii -html <filter.xml >filter-info.xml
168e428f 42
f89d2485
PH
43filter.fo: filter-pr.xml MyStyle-filter-fo.xsl MyStyle-fo.xsl MyStyle.xsl
44 /bin/rm -rf filter.fo filter-pr.fo
45 xmlto -x MyStyle-filter-fo.xsl fo filter-pr.xml
46 /bin/mv -f filter-pr.fo filter.fo
168e428f 47
deca074a
PH
48# Do not use pdf2ps from the PDF version; better PS is generated directly.
49
f89d2485
PH
50###
51### PS/PDF generation using fop
52###
53
54fop-filter.ps: filter.fo
55 fop filter.fo -ps filter-tmp.ps
56 mv filter-tmp.ps filter.ps
168e428f 57
deca074a
PH
58# Do not use ps2pdf from the PS version; better PDF is generated directly. It
59# contains cross links etc.
d1e83bff 60
f89d2485
PH
61fop-filter.pdf: filter.fo PageLabelPDF
62 fop filter.fo -pdf filter-tmp.pdf
63 ./PageLabelPDF 2 <filter-tmp.pdf >filter.pdf
64
65###
66### PS/PDF generation using SDoP
67###
68
69sdop-filter.ps: filter-pr.xml
70 sdop -o filter.ps filter-pr.xml
71
4aa45c31 72sdop-filter.pdf: filter.ps
f89d2485
PH
73 ps2pdf filter.ps filter.pdf
74
75###
76### PS/PDF default setting
77###
78
79filter.ps: sdop-filter.ps
80
81filter.pdf: sdop-filter.pdf
82
83###
84###
168e428f 85
9b371988
PH
86filter.txt: filter-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
87 MyStyle.xsl
168e428f
PH
88 /bin/rm -rf filter-txt.html
89 xmlto -x MyStyle-txt-html.xsl html-nochunks filter-txt.xml
9b371988 90 w3m -dump filter-txt.html | ./Tidytxt >filter.txt
168e428f
PH
91
92# I have not found a way of making docbook2texi write its output anywhere
93# other than the file name that it makes up. The --to-stdout option does not
94# work.
95
9b371988
PH
96filter.info: filter-info.xml
97 docbook2texi filter-info.xml
168e428f 98 perl -ne 's/conceptindex/cindex/;s/optionindex/findex/;print;' \
207c78ae 99 <exim_filtering.texi | ./Tidytxt >filter.texinfo
168e428f
PH
100 /bin/rm -rf exim_filtering.texi
101 makeinfo -o filter.info filter.texinfo
102
103########################################################################
104
105
106################################ SPEC ##################################
107
f89d2485
PH
108spec.xml: spec.xfpt
109 xfpt spec.xfpt
168e428f 110
f89d2485
PH
111spec-pr.xml: spec.xml Pre-xml
112 ./Pre-xml -optbreak <spec.xml >spec-pr.xml
168e428f 113
f89d2485
PH
114spec-txt.xml: spec.xml Pre-xml
115 ./Pre-xml -ascii -html -noindex -quoteliteral \
116 <spec.xml >spec-txt.xml
9b371988
PH
117
118spec-info.xml: spec.xml Pre-xml
f89d2485
PH
119 ./Pre-xml -ascii -html -noindex <spec.xml >spec-info.xml
120
121spec.fo: spec-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \
122 MyTitleStyle.xsl
123 /bin/rm -rf spec.fo spec-pr.fo
124 xmlto -x MyStyle-spec-fo.xsl fo spec-pr.xml
125 /bin/mv -f spec-pr.fo spec.fo
168e428f 126
f89d2485
PH
127###
128### PS/PDF generation using fop
129###
168e428f 130
deca074a
PH
131# Do not use pdf2ps from the PDF version; better PS is generated directly.
132
f89d2485 133fop-spec.ps: spec.fo
068aaea8
PH
134 FOP_OPTS=-Xmx512m fop spec.fo -ps spec-tmp.ps
135 mv spec-tmp.ps spec.ps
168e428f 136
deca074a 137# Do not use ps2pdf from the PS version; better PDF is generated directly. It
9b371988
PH
138# contains cross links etc. We post-process it to add page label information
139# so that the page identifiers shown by acroread are the correct page numbers.
d1e83bff 140
f89d2485 141fop-spec.pdf: spec.fo PageLabelPDF
deca074a 142 FOP_OPTS=-Xmx512m fop spec.fo -pdf spec-tmp.pdf
4f578862 143 ./PageLabelPDF 12 <spec-tmp.pdf >spec.pdf
168e428f 144
f89d2485
PH
145###
146### PS/PDF generation using SDoP
147###
148
149sdop-spec.ps: spec-pr.xml
150 sdop -o spec.ps spec-pr.xml
151
4aa45c31 152sdop-spec.pdf: spec.ps
f89d2485
PH
153 ps2pdf spec.ps spec.pdf
154
155###
156### PS/PDF default setting
157###
158
159spec.ps: sdop-spec.ps
160
161spec.pdf: sdop-spec.pdf
162
163###
164###
165
9b371988
PH
166spec.txt: spec-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
167 MyStyle.xsl
168e428f
PH
168 /bin/rm -rf spec-txt.html
169 xmlto -x MyStyle-txt-html.xsl html-nochunks spec-txt.xml
9b371988 170 w3m -dump spec-txt.html | ./Tidytxt >spec.txt
168e428f
PH
171
172# I have not found a way of making docbook2texi write its output anywhere
173# other than the file name that it makes up. The --to-stdout option does not
174# work.
175
9b371988
PH
176spec.info: spec-info.xml
177 docbook2texi spec-info.xml
4f578862 178 ./TidyInfo <the_exim_mta.texi >spec.texinfo
168e428f 179 /bin/rm -rf the_exim_mta.texi
595028e4 180 makeinfo -o spec.info --no-split spec.texinfo
168e428f
PH
181
182########################################################################
183
184
185################################ TEST ##################################
186
187# These targets (similar to the above) are for running little tests.
188
9b371988
PH
189test.xml: test.xfpt
190 xfpt test.xfpt
168e428f 191
f89d2485
PH
192test-pr.xml: test.xml Pre-xml
193 ./Pre-xml <test.xml >test-pr.xml
168e428f
PH
194
195test-html.xml: test.xml Pre-xml
9b371988 196 ./Pre-xml -html -oneindex <test.xml >test-html.xml
168e428f
PH
197
198test-txt.xml: test.xml Pre-xml
9b371988
PH
199 ./Pre-xml -ascii -html -noindex -quoteinfo \
200 <test.xml >test-txt.xml
201
202test-info.xml: test.xml Pre-xml
203 ./Pre-xml -ascii -html -noindex <test.xml >test-info.xml
168e428f 204
f89d2485 205test.fo: test-pr.xml MyStyle-spec-fo.xsl MyStyle-fo.xsl MyStyle.xsl \
9b371988 206 MyTitleStyle.xsl
f89d2485
PH
207 /bin/rm -rf test.fo test-pr.fo
208 xmlto -x MyStyle-spec-fo.xsl fo test-pr.xml
209 /bin/mv -f test-pr.fo test.fo
210
211###
212### PS/PDF generation using fop
213###
168e428f 214
deca074a
PH
215# Do not use pdf2ps from the PDF version; better PS is generated directly.
216
f89d2485 217fop-test.ps: test.fo
068aaea8
PH
218 fop test.fo -ps test-tmp.ps
219 mv test-tmp.ps test.ps
168e428f 220
deca074a
PH
221# Do not use ps2pdf from the PS version; better PDF is generated directly. It
222# contains cross links etc.
d1e83bff 223
f89d2485 224fop-test.pdf: test.fo
deca074a
PH
225 fop test.fo -pdf test-tmp.pdf
226 mv test-tmp.pdf test.pdf
168e428f 227
f89d2485
PH
228###
229### PS/PDF generation using SDoP
230###
231
232sdop-test.ps: test-pr.xml
233 sdop -o test.ps test-pr.xml
234
4aa45c31 235sdop-test.pdf: test.ps
f89d2485
PH
236 ps2pdf test.ps test.pdf
237
238###
239### PS/PDF default setting
240###
241
242test.ps: sdop-test.ps
243
244test.pdf: sdop-test.pdf
245
246###
247###
248
249
9b371988
PH
250test.txt: test-txt.xml Tidytxt MyStyle-txt-html.xsl MyStyle-html.xsl \
251 MyStyle.xsl
168e428f
PH
252 /bin/rm -rf test-txt.html
253 xmlto -x MyStyle-txt-html.xsl html-nochunks test-txt.xml
254 w3m -dump test-txt.html | Tidytxt >test.txt
255
256# I have not found a way of making docbook2texi write its output anywhere
257# other than the file name that it makes up. The --to-stdout option does not
258# work.
259
9b371988
PH
260test.info: test-info.xml
261 docbook2texi test-info.xml
4f578862 262 ./TidyInfo <short_title.texi >test.texinfo
168e428f
PH
263 /bin/rm -rf short_title.texi
264 makeinfo -o test.info test.texinfo
265
266########################################################################
267
268
a2119650
NM
269############################## OS FIXUP ################################
270
271# Yes, we've advanced so far in text processing that we now have to
272# hardcode in complete paths and so become dependent upon exactly where
273# files were installed for xsl:import. Which of course varies by OS.
274
275os-fixup:
276 ./OS-Fixups
277
278########################################################################
279
280
168e428f
PH
281################################ CLEAN #################################
282
283clean:; /bin/rm -rf exim.8 \
284 filter*.xml spec*.xml test*.xml \
285 *.fo *.html *.pdf *.ps \
286 filter*.txt spec*.txt test*.txt \
287 *.info* *.texinfo *.texi
288
289########################################################################