1 ## PSPP - a program for statistical analysis.
2 ## Copyright (C) 2019, 2020 Free Software Foundation, Inc.
4 ## This program is free software: you can redistribute it and/or modify
5 ## it under the terms of the GNU General Public License as published by
6 ## the Free Software Foundation, either version 3 of the License, or
7 ## (at your option) any later version.
9 ## This program is distributed in the hope that it will be useful,
10 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
11 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 ## GNU General Public License for more details.
14 ## You should have received a copy of the GNU General Public License
15 ## along with this program. If not, see <http://www.gnu.org/licenses/>.
17 ## Process this file with automake to produce Makefile.in -*- makefile -*-
19 info_TEXINFOS = doc/pspp.texi doc/pspp-dev.texi
21 doc_pspp_TEXINFOS = doc/version.texi \
23 doc/command-index.texi \
24 doc/concept-index.texi \
26 doc/data-selection.texi \
27 doc/expressions.texi \
30 doc/flow-control.texi \
31 doc/function-index.texi \
33 doc/introduction.texi \
37 doc/pspp-convert.texi \
38 doc/pspp-output.texi \
39 doc/pspp-dump-sav.texi \
41 doc/not-implemented.texi \
43 doc/transformation.texi \
51 doc_pspp_dev_TEXINFOS = doc/version-dev.texi \
53 doc/dev/concepts.texi \
58 doc/dev/system-file-format.texi \
59 doc/dev/pc+-file-format.texi \
60 doc/dev/portable-file-format.texi \
61 doc/dev/spv-file-format.texi \
62 doc/dev/encrypted-file-wrappers.texi \
65 dist_man_MANS += doc/pspp.1 \
68 EXTRA_DIST += doc/get-commands.pl \
72 $(srcdir)/doc/ni.texi: $(top_srcdir)/src/language/command.def doc/get-commands.pl
73 $(AM_V_GEN)$(PERL) $(top_srcdir)/doc/get-commands.pl $(top_srcdir)/src/language/command.def > $@
75 $(srcdir)/doc/tut.texi:
76 $(AM_V_GEN)echo "@set example-dir $(examplesdir)" > $@
79 doc/pspp.xml: doc/pspp.texi $(doc_pspp_TEXINFOS) doc/help-pages-list
83 $(AM_V_GEN)$(MAKEINFO) $(AM_MAKEINFOFLAGS) --docbook -I $(top_srcdir) \
87 docbookdir = $(docdir)
88 dist_docbook_DATA = doc/pspp.xml
91 CLEANFILES += pspp-dev.dvi $(docbook_DATA) doc/pspp.info* doc/pspp.xml
94 doc: $(INFO_DEPS) $(DVIS) $(PDFS) $(PSS) $(HTMLS) $(dist_docbook_DATA)
97 doc/help-pages-list: $(UI_FILES)
98 $(AM_V_GEN)cat $^ | grep '"help[-_]page"' | \
99 $(SED) -e 's% *<property name="help[-_]page">\([^<]*\)</property>%//*[@id='"'"'\1'"'"']%' \
100 -e 's%#%'"'"']/*[@id='"'"'%g' > $@,tmp
105 doc/help-pages-list \
109 AM_MAKEINFOFLAGS=-I $(top_srcdir)/doc/examples -I $(top_builddir)/doc/examples
110 am__TEXINFO_TEX_DIR=:$(top_srcdir)/doc/examples:$(top_builddir)/doc/examples
112 ################# Example programs ##############################
115 doc/examples/autorecode.sps \
116 doc/examples/chisquare.sps \
117 doc/examples/compute.sps \
118 doc/examples/count.sps \
119 doc/examples/descriptives.sps \
120 doc/examples/flip.sps \
121 doc/examples/frequencies.sps \
122 doc/examples/means.sps \
123 doc/examples/one-sample-t.sps \
124 doc/examples/independent-samples-t.sps \
125 doc/examples/reliability.sps \
126 doc/examples/split.sps \
127 doc/examples/weight.sps
130 EXTRA_DIST += $(EXAMPLE_SYNTAX)
132 EXAMPLE_OUTPUTS = $(EXAMPLE_SYNTAX:.sps=.out)
133 EXAMPLE_HTML = $(EXAMPLE_SYNTAX:.sps=.html)
135 example-outputs: $(EXAMPLE_OUTPUTS)
136 example-html: $(EXAMPLE_HTML)
137 PHONY += example-outputs example-html
139 $(top_builddir)/doc/pspp.info: $(EXAMPLE_OUTPUTS)
140 $(top_builddir)/doc/pspp.ps: $(EXAMPLE_OUTPUTS)
141 $(top_builddir)/doc/pspp.dvi: $(EXAMPLE_OUTPUTS)
142 $(top_builddir)/doc/pspp.html: $(EXAMPLE_HTML)
143 $(top_builddir)/doc/pspp.pdf: $(EXAMPLE_OUTPUTS)
144 $(top_builddir)/doc/pspp.xml: $(EXAMPLE_OUTPUTS)
146 # The examples cannot be built until the binary has been built
147 $(EXAMPLE_OUTPUTS): $(top_builddir)/src/ui/terminal/pspp
148 $(EXAMPLE_HTML): $(top_builddir)/src/ui/terminal/pspp
150 CLEANFILES += $(EXAMPLE_OUTPUTS)
154 # use pspp to process a syntax file and reap the output into a text file
157 (cd $(top_srcdir)/examples; ${abs_builddir}/src/ui/terminal/pspp $(abs_srcdir)/doc/examples/$(<F) -o $$where/$@)
159 # Use pspp to process a syntax file and reap the output into a html file
160 # Then, use sed to delete everything up to and including <body> and
161 # everything after and including </body>
164 (cd $(top_srcdir)/examples; ${abs_builddir}/src/ui/terminal/pspp $(abs_srcdir)/doc/examples/$(<F) -o $$where/$@,x -O format=html)
165 $(SED) -e '\%</body%,$$d' -e '0,/<body/d' $@,x > $@
167 # Insert the link tag for the cascading style sheet.
168 # But make sure these operations are idempotent.
170 for h in doc/pspp.html/*.html; do \
171 if grep -Fq '<link rel="stylesheet"' $$h; then continue; fi ; \
172 $(SED) -i -e '/^<\/head>/i \\\
173 <link rel="stylesheet" href="pspp-manual.css">' $$h; \
176 install-html-local: html-local
177 $(MKDIR_P) $(DESTDIR)$(prefix)/share/doc/pspp/pspp.html
178 $(INSTALL_DATA) ${top_srcdir}/doc/pspp-manual.css $(DESTDIR)$(prefix)/share/doc/pspp/pspp.html
183 desktopdir = $(datadir)/applications
185 doc/org.fsf.pspp.metainfo.xml: doc/org.fsf.pspp.metainfo.xml.in $(POFILES)
186 $(AM_V_GEN)$(MSGFMT) --xml --template $< -o $@ -d $(top_srcdir)/po || \
187 $(MSGFMT) -L appdata --xml --template $< -o $@ -d $(top_srcdir)/po
189 doc/org.fsf.pspp.desktop: doc/org.fsf.pspp.desktop.in $(POFILES)
190 $(AM_V_GEN)$(MSGFMT) --desktop --template $< -o $@ -d $(top_srcdir)/po
192 CLEANFILES+=doc/org.fsf.pspp.desktop \
193 doc/org.fsf.pspp.metainfo.xml
195 desktop_DATA = doc/org.fsf.pspp.desktop
197 appdatadir = $(datadir)/metainfo
198 dist_appdata_DATA = doc/org.fsf.pspp.metainfo.xml
200 EXTRA_DIST += doc/org.fsf.pspp.metainfo.xml.in \
201 doc/org.fsf.pspp.desktop.in