forked from zendframework/zendframework
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile.in
157 lines (129 loc) · 4.97 KB
/
Makefile.in
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
#
# Zend Framework
#
# LICENSE
#
# This source file is subject to the new BSD license that is bundled
# with this package in the file LICENSE.txt.
# It is also available through the world-wide-web at this URL:
# http://framework.zend.com/license/new-bsd
# If you did not receive a copy of the license and are unable to
# obtain it through the world-wide-web, please send an email
# to [email protected] so we can send you a copy immediately.
#
# @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
# @license http://framework.zend.com/license/new-bsd New BSD License
#
#
# Makefile - build Zend Framework product and documentation
#
# Main targets:
# all - render DocBook manual in HTML.
# clean - remove staged files.
# check - validate DocBook manual using xmllint.
# check1 - validate one DocBook XML file using xmllint.
# Requires that you set the XMLFILE variable.
# pdf-print - PDF version of manual, in two volumes; requires Apache FOP
# pdf - PDF version of manual, in a single volume; requires Apache FOP
#
# -- parameters you are likely to want to change --
# XMLFILE is the name of one DocBook XML file that you want to
# test with xmllint, using the 'check1' target.
XSLTPROC=@XSLTPROC@
XMLLINT=@XMLLINT@
FOP=@FOP@
ECSRC=@ECSRC@
HERE=@HERE@
# Docbook 5 DTD
DOCBOOK_DTD?=http://www.docbook.org/xml/5.0/dtd/docbook.dtd
# You should grab the docbook-xsl-ns HTML chunk.xsl stylesheet and add it
# via an environment variable for best results.
DOCBOOK_XSL?=http://framework.zend.com/docbook-xsl/htmlhelp/htmlhelp.xsl
# For rendering PDF
DOCBOOK_FO_XSL?=http://framework.zend.com/docbook-xsl/fo/docbook.xsl
# Local modifications
HTML_XSL=html.xsl
MANUAL_XML=manual.xml
MANUAL_PRINT1_XML=manual-print1.xml
MANUAL_PRINT2_XML=manual-print2.xml
MANUAL_LINT_XML=../en/manual-lint.xml.in
MODULE=module_specs
PDF_XSL=pdf-manual.xsl
XMLFILE=
all: $(MANUAL_XML) html
# Build the docs in HTML format
html: html/index.html
html/index.html: $(MANUAL_XML) $(HTML_XSL)
@echo "Rendering the whole manual with $(XSLTPROC)..."
$(XMLLINT) --xinclude --output _temp_manual.xml $(MANUAL_XML)
$(XSLTPROC) --xinclude --output html/index.html $(HTML_XSL) _temp_manual.xml
@echo "Copying manual figures (recursively)..."
-[ -d figures ] && cp -r figures html/
$(MANUAL_XML): ../en/$(MANUAL_XML).in
sed -e 's!@DOCBOOK_DTD@!$(DOCBOOK_DTD)!' $< > $@
$(HTML_XSL): ../en/$(HTML_XSL).in
sed -e 's!@DOCBOOK_XSL@!$(DOCBOOK_XSL)!' $< > $@
# Build the docs in PDF format
pdf-print: pdf-print-volume1 pdf-print-volume2
pdf-dir:
@if [ ! -e pdf ]; then \
mkdir pdf; \
fi
pdf: pdf-dir $(MANUAL_XML) $(PDF_XSL)
@echo "Rendering of the PDF manual with $(FOP)..."
$(XMLLINT) --xinclude --output _temp_manual.xml $(MANUAL_XML)
$(XSLTPROC) --xinclude --output ZendFramework.fo $(PDF_XSL) _temp_manual.xml
"$(FOP)" -fo ZendFramework.fo -pdf pdf/ZendFramework.pdf
pdf-print-volume1: pdf-dir $(PDF_XSL) $(MANUAL_PRINT1_XML)
@echo "Rendering volume 1 of the PDF manual with $(FOP)..."
$(XMLLINT) --xinclude --output _temp_manual_1.xml $(MANUAL_PRINT1_XML)
$(XSLTPROC) --xinclude --output ZendFramework.fo $(PDF_XSL) _temp_manual_1.xml
"$(FOP)" -fo ZendFramework.fo -pdf pdf/ZendFrameworkVolume1.pdf
pdf-print-volume2: pdf-dir $(PDF_XSL) $(MANUAL_PRINT2_XML)
@echo "Rendering volume 2 of the PDF manual with $(FOP)..."
$(XMLLINT) --xinclude --output _temp_manual_2.xml $(MANUAL_PRINT2_XML)
$(XSLTPROC) --xinclude --output ZendFramework.fo $(PDF_XSL) _temp_manual_2.xml
"$(FOP)" -fo ZendFramework.fo -pdf pdf/ZendFrameworkVolume2.pdf
$(MANUAL_PRINT1_XML): ../en/$(MANUAL_PRINT1_XML).in
sed -e 's!@DOCBOOK_DTD@!$(DOCBOOK_DTD)!' $< > $@
$(MANUAL_PRINT2_XML): ../en/$(MANUAL_PRINT2_XML).in
sed -e 's!@DOCBOOK_DTD@!$(DOCBOOK_DTD)!' $< > $@
$(PDF_XSL): ../en/$(PDF_XSL).in
sed -e 's!@DOCBOOK_FO_XSL@!$(DOCBOOK_FO_XSL)!' $< > $@
# Cleanup
check: $(MANUAL_XML)
@echo "Checking the whole manual with $(XMLLINT)..."
@$(XMLLINT) --xinclude --output _temp_manual.xml $(MANUAL_XML)
@$(XMLLINT) --valid --noout --postvalid _temp_manual.xml \
&& echo "OK"
check1: $(MANUAL_LINT_XML)
@if [ -n "$(XMLFILE)" ] ; then \
if [ -f "$(MODULE)/$(XMLFILE)" ] ; then \
echo "Checking $(XMLFILE) with $(XMLLINT)..." ; \
sed -e 's!@XMLFILE@!$(MODULE)/$(XMLFILE)!' -e 's!@DOCBOOK_DTD@!$(DOCBOOK_DTD)!' $(MANUAL_LINT_XML) \
| $(XMLLINT) --xinclude --output _temp_$(XMLFILE) - ; \
$(XMLLINT) --valid --noout --postvalid _temp_$(XMLFILE) \
&& echo "OK" ; \
else \
echo "File $(MODULE)/$(XMLFILE) not found." ; \
fi ; \
else \
echo "Please specify a filename, e.g. 'make XMLFILE=filename.xml check1'" ; \
fi
clean:
-rm -f html/*.html html/HTML.manifest
@if [ -d html/figures ] ; then \
rm -Rf html/figures ; \
fi
@if [ -d pdf ] ; then \
rm -Rf pdf ; \
fi
-rm -f _temp_*.xml
-rm -f /*.pdf
-rm -f ZendFramework.fo
-rm -f err.txt
cleanall: clean
-rm -f config.* configure
-rm -rf autom4te.cache
-rm -f Makefile
-rm -f $(HTML_XSL) $(MANUAL_XML) $(MANUAL_PRINT1_XML) $(MANUAL_PRINT2_XML) $(PDF_XSL)