Daily bump.
[official-gcc.git] / libstdc++-v3 / doc / Makefile.am
blobbe38a5f317a746a590e11cbab943084ae08bd5f0
1 ## Makefile for the doc subdirectory of the GNU C++ Standard library.
2 ##
3 ## Copyright (C) 2008-2024 Free Software Foundation, Inc.
4 ##
5 ## This file is part of the libstdc++ version 3 distribution.
6 ## Process this file with automake to produce Makefile.in.
8 ## This file is part of the GNU ISO C++ Library.  This library is free
9 ## software; you can redistribute it and/or modify it under the
10 ## terms of the GNU General Public License as published by the
11 ## Free Software Foundation; either version 3, or (at your option)
12 ## any later version.
14 ## This library is distributed in the hope that it will be useful,
15 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
16 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 ## GNU General Public License for more details.
19 ## You should have received a copy of the GNU General Public License along
20 ## with this library; see the file COPYING3.  If not see
21 ## <http://www.gnu.org/licenses/>.
23 include $(top_srcdir)/fragment.am
25 # Documentation Overview
27 # See ./xml/manual/documentation_hacking.xml for full details.
29 # There are two main input materials for libstdc++ documentation.
30 # The first is the doxygen markup in libstdc++ sources, which is a
31 # reference to the API. And the second is the manual, via docbook markup in
32 # doc/xml/.
34 # A third and more obscure option deals with charting performance
35 # tests, and should be considered experimental.
37 # Documentation conditionals for output.
38 if BUILD_XML
39 STAMP_XML = doc-xml
40 STAMP_INSTALL_XML = doc-install-xml
41 else
42 STAMP_XML =
43 STAMP_INSTALL_XML =
44 endif
46 if BUILD_HTML
47 STAMP_HTML = doc-html
48 STAMP_INSTALL_HTML = doc-install-html
49 else
50 STAMP_HTML =
51 STAMP_INSTALL_HTML =
52 endif
54 if BUILD_MAN
55 STAMP_MAN = doc-man
56 STAMP_INSTALL_MAN = doc-install-man
57 else
58 STAMP_MAN =
59 STAMP_INSTALL_MAN =
60 endif
62 if BUILD_PDF
63 STAMP_PDF = doc-pdf
64 STAMP_INSTALL_PDF = doc-install-pdf
65 else
66 STAMP_PDF =
67 STAMP_INSTALL_PDF =
68 endif
70 if BUILD_EPUB
71 STAMP_EPUB = doc-epub
72 STAMP_INSTALL_EPUB = doc-install-epub
73 else
74 STAMP_EPUB = doc-epub
75 STAMP_INSTALL_EPUB = doc-install-epub
76 endif
78 # Documentation primary rules.
80 # xml:
81 # html:
82 # pdf:
83 # man:
84 # info:
85 # ps:
86 # dvi:
87 # epub:
88 # install-xml:
89 # install-html:
90 # install-pdf:
91 # install-man:
92 # install-info:
93 # install-ps:
94 # install-dvi:
95 # install-epub:
97 xml: $(STAMP_XML)
98 install-xml: $(STAMP_INSTALL_XML)
100 html: $(STAMP_HTML)
101 install-html: $(STAMP_INSTALL_HTML)
103 man: $(STAMP_MAN)
104 install-man: $(STAMP_INSTALL_MAN)
106 pdf: $(STAMP_PDF)
107 install-pdf: $(STAMP_INSTALL_PDF)
109 epub: $(STAMP_EPUB)
110 install-epub: $(STAMP_INSTALL_EPUB)
112 info:
113 install-info:
116 install-ps:
118 dvi:
119 install-dvi:
122 # Default creation and installation rules.
123 # Point to best sub-rule for the requested documentation target and
124 # create, and then install toplevel directory with standardized names
125 # and layouts.
127 # XML
128 xmldir="$(DESTDIR)@docdir@"
129 stamp-xml: stamp-xml-single-docbook stamp-xml-single-doxygen
130         $(STAMP) stamp-xml
132 doc-xml: stamp-xml
134 doc-install-xml: doc-xml
135         test -z ${xmldir} || $(mkinstalldirs) ${xmldir}
136         $(INSTALL_DATA) ${manual_xml} ${xmldir}
137         $(INSTALL_DATA) ${api_xml} ${xmldir}
139 # HTML
140 htmldir="$(DESTDIR)@docdir@"
141 stamp-html: stamp-html-docbook-data stamp-html-doxygen
142         $(STAMP) stamp-html
144 doc-html: stamp-html
146 doc-install-html: doc-html
147         test -z ${htmldir} || $(mkinstalldirs) ${htmldir}
148         cp -r ${docbook_outdir}/html ${htmldir}/libstdc++-manual.html;
149         cp -r ${doxygen_outdir}/html ${htmldir}/libstdc++-api.html;
151 # PDF
152 pdfdir="$(DESTDIR)@docdir@"
153 stamp-pdf: stamp-pdf-docbook stamp-pdf-doxygen
154         $(STAMP) stamp-pdf
156 doc-pdf: stamp-pdf
158 doc-install-pdf: doc-pdf
159         test -z ${pdfdir} || $(mkinstalldirs) ${pdfdir}
160         $(INSTALL_DATA) ${docbook_outdir}/pdf/libstdc++-manual.pdf ${pdfdir}
161         $(INSTALL_DATA) ${doxygen_outdir}/pdf/libstdc++-api.pdf ${pdfdir}
163 # MAN
164 mandir="$(DESTDIR)@mandir@"
165 stamp-man: stamp-man-doxygen
166         $(STAMP) stamp-man
168 doc-man: stamp-man
170 doc-install-man: doc-man
171         test -z ${mandir} || $(mkinstalldirs) ${mandir}
172         cp -r ${doxygen_outdir}/man/man3 ${mandir}
174 # TEXINFO,INFO
175 infodir="$(DESTDIR)@infodir@"
176 stamp-texinfo: stamp-texinfo-docbook
177         $(STAMP) stamp-texinfo
179 stamp-info: stamp-info-docbook
180         $(STAMP) stamp-info
182 doc-texinfo: stamp-texinfo
184 doc-info: stamp-info
186 doc-install-texinfo: doc-texinfo
187         test -z ${infodir} || $(mkinstalldirs) ${infodir}
188         $(INSTALL_DATA) ${manual_texi} ${infodir}
190 doc-install-info: doc-info
191         test -z ${infodir} || $(mkinstalldirs) ${infodir}
192         $(INSTALL_DATA) ${manual_info} ${infodir}
194 # EPUB
195 # Assumes ruby installed
196 epubdir="$(DESTDIR)@docdir@"
197 stamp-epub: stamp-epub-docbook
198         $(STAMP) stamp-epub
200 doc-epub: stamp-epub
202 doc-install-epub: doc-epub
203         test -z ${epubdir} || $(mkinstalldirs) ${epubdir}
204         $(INSTALL_DATA) ${manual_epub} ${epubdir}
207 # Doxygen configuration
208 # Assumes doxygen, graphviz (with dot), pdflatex installed
209 doxygen_script=${top_srcdir}/scripts/run_doxygen
210 doxygen_outdir = ${glibcxx_builddir}/doc/doxygen
211 api_xml = ${doxygen_outdir}/xml/libstdc++-api.xml
212 doxygen_pdf = ${doxygen_outdir}/latex/refman.pdf
213 api_pdf = ${doxygen_outdir}/pdf/libstdc++-api.pdf
215 ${doxygen_outdir}/xml:
216         mkdir -p ${doxygen_outdir}/xml
218 ${doxygen_outdir}/html:
219         mkdir -p ${doxygen_outdir}/html
221 ${doxygen_outdir}/latex:
222         mkdir -p ${doxygen_outdir}/latex
224 ${doxygen_outdir}/pdf:
225         mkdir -p ${doxygen_outdir}/pdf
227 ${doxygen_outdir}/man:
228         mkdir -p ${doxygen_outdir}/man
230 stamp-xml-doxygen: ${doxygen_outdir}/xml
231         -srcdir=`cd ${top_srcdir}; ${PWD_COMMAND}`; \
232           builddir=`cd ..; ${PWD_COMMAND}`; \
233           ${SHELL} ${doxygen_script} \
234           --host_alias=${host_alias} --mode=xml \
235           "$${srcdir}" "$${builddir}" NO
236         $(STAMP) stamp-xml-doxygen
238 stamp-xml-single-doxygen: stamp-xml-doxygen
239         @echo "Generating doxygen xml single file..."
240         $(XSLTPROC) ${doxygen_outdir}/xml/combine.xslt \
241         ${doxygen_outdir}/xml/index.xml > ${api_xml};
242         $(STAMP) stamp-xml-single-doxygen
244 stamp-html-doxygen: ${doxygen_outdir}/html
245         -srcdir=`cd ${top_srcdir}; ${PWD_COMMAND}`; \
246           builddir=`cd ..; ${PWD_COMMAND}`; \
247           ${SHELL} ${doxygen_script} \
248           --host_alias=${host_alias} --mode=html \
249           "$${srcdir}" "$${builddir}" YES
250         $(STAMP) stamp-html-doxygen
252 stamp-latex-doxygen: ${doxygen_outdir}/latex
253         -srcdir=`cd ${top_srcdir}; ${PWD_COMMAND}`; \
254           builddir=`cd ..; ${PWD_COMMAND}`; \
255           ${SHELL} ${doxygen_script} \
256           --host_alias=${host_alias} --mode=latex --latex_cmd=$(LATEX_CMD) \
257           "$${srcdir}" "$${builddir}" NO
258         $(STAMP) stamp-latex-doxygen
260 # Chance of loooooonnggg creation time on this rule.  Iff this fails,
261 # look at refman.log and see if TeX's memory is exhausted. Symptoms
262 # include asking a wizard to enlarge capacity. If this is the case,
263 # find texmf.cnf and add a zero for pool_size, string_vacancies,
264 # max_strings, and pool_free values. A much simpler workaround is to
265 # install lualatex and set LATEX_CMD=lualatex when running make.
266 # Errors like "File `foo.sty' not found" mean a TeX package is missing.
267 stamp-pdf-doxygen: stamp-latex-doxygen ${doxygen_outdir}/pdf
268         @echo "Generating doxygen pdf file...";
269         -$(MAKE) -C ${doxygen_outdir}/latex -i pdf
270         @if [ -f ${doxygen_pdf} ]; then \
271           mv ${doxygen_pdf} ${api_pdf} ; \
272           echo ":: PDF file is ${api_pdf}"; \
273         else \
274           echo "... error"; \
275           grep -F 'LaTeX Error' ${doxygen_outdir}/latex/refman.log; \
276           grep -F 'TeX capacity exceeded, sorry' ${doxygen_outdir}/latex/refman.log; \
277           exit 12; \
278         fi
279         $(STAMP) stamp-pdf-doxygen
281 stamp-man-doxygen: ${doxygen_outdir}/man
282         -srcdir=`cd ${top_srcdir}; ${PWD_COMMAND}`; \
283           builddir=`cd ..; ${PWD_COMMAND}`; \
284           ${SHELL} ${doxygen_script} \
285           --host_alias=${host_alias} --mode=man \
286           "$${srcdir}" "$${builddir}" YES
287         $(STAMP) stamp-man-doxygen
289 doc-xml-doxygen: stamp-xml-doxygen
290 doc-xml-single-doxygen: stamp-xml-single-doxygen
291 doc-html-doxygen: stamp-html-doxygen
292 doc-latex-doxygen: stamp-latex-doxygen
293 doc-pdf-doxygen: stamp-pdf-doxygen
294 doc-man-doxygen: stamp-man-doxygen
297 # Docbook configuration.
298 # Assumes
299 # libxslt
300 # dblatex
301 # pdflatex
302 # docbook-style-xsl
303 # emacs-nxml-mode
304 docbook_outdir = ${glibcxx_builddir}/doc/docbook
305 xml_dir = ${glibcxx_srcdir}/doc/xml
307 xml_sources_basic = \
308         ${xml_dir}/spine.xml \
309         ${xml_dir}/authors.xml \
310         ${xml_dir}/api.xml \
311         ${xml_dir}/faq.xml
313 xml_sources_manual = \
314         ${xml_dir}/manual/abi.xml \
315         ${xml_dir}/manual/algorithms.xml \
316         ${xml_dir}/manual/allocator.xml \
317         ${xml_dir}/manual/auto_ptr.xml \
318         ${xml_dir}/manual/atomics.xml \
319         ${xml_dir}/manual/backwards_compatibility.xml \
320         ${xml_dir}/manual/bitmap_allocator.xml \
321         ${xml_dir}/manual/build_hacking.xml \
322         ${xml_dir}/manual/codecvt.xml \
323         ${xml_dir}/manual/concurrency.xml \
324         ${xml_dir}/manual/concurrency_extensions.xml \
325         ${xml_dir}/manual/configure.xml \
326         ${xml_dir}/manual/containers.xml \
327         ${xml_dir}/manual/ctype.xml \
328         ${xml_dir}/manual/debug_mode.xml \
329         ${xml_dir}/manual/debug.xml \
330         ${xml_dir}/manual/diagnostics.xml \
331         ${xml_dir}/manual/documentation_hacking.xml \
332         ${xml_dir}/manual/evolution.xml \
333         ${xml_dir}/manual/extensions.xml \
334         ${xml_dir}/manual/internals.xml \
335         ${xml_dir}/manual/intro.xml \
336         ${xml_dir}/manual/io.xml \
337         ${xml_dir}/manual/iterators.xml \
338         ${xml_dir}/manual/locale.xml \
339         ${xml_dir}/manual/localization.xml \
340         ${xml_dir}/manual/messages.xml \
341         ${xml_dir}/manual/mt_allocator.xml \
342         ${xml_dir}/manual/numerics.xml \
343         ${xml_dir}/manual/parallel_mode.xml \
344         ${xml_dir}/manual/policy_data_structures.xml \
345         ${xml_dir}/manual/policy_data_structures_biblio.xml \
346         ${xml_dir}/manual/prerequisites.xml \
347         ${xml_dir}/manual/shared_ptr.xml \
348         ${xml_dir}/manual/spine.xml \
349         ${xml_dir}/manual/status_cxx1998.xml \
350         ${xml_dir}/manual/status_cxx2011.xml \
351         ${xml_dir}/manual/status_cxx2014.xml \
352         ${xml_dir}/manual/status_cxx2017.xml \
353         ${xml_dir}/manual/status_cxx2020.xml \
354         ${xml_dir}/manual/status_cxxtr1.xml \
355         ${xml_dir}/manual/status_cxxtr24733.xml \
356         ${xml_dir}/manual/strings.xml \
357         ${xml_dir}/manual/support.xml \
358         ${xml_dir}/manual/test.xml \
359         ${xml_dir}/manual/test_policy_data_structures.xml \
360         ${xml_dir}/manual/using.xml \
361         ${xml_dir}/manual/using_exceptions.xml \
362         ${xml_dir}/manual/utilities.xml \
363         ${xml_dir}/manual/appendix_free.xml \
364         ${xml_dir}/manual/appendix_contributing.xml \
365         ${xml_dir}/manual/appendix_porting.xml
367 xml_sources_extra = \
368         ${xml_dir}/gnu/fdl-1.3.xml \
369         ${xml_dir}/gnu/gpl-3.0.xml
371 xml_sources = \
372         ${xml_sources_basic} \
373         ${xml_sources_manual} \
374         ${xml_sources_extra}
376 xml_image_dir = ${xml_dir}/images
377 xml_image_basic = \
378         ${xml_image_dir}/confdeps.png \
379         ${xml_image_dir}/pbds_balls_and_bins.png \
380         ${xml_image_dir}/pbds_container_tag_hierarchy.png \
381         ${xml_image_dir}/pbds_different_underlying_dss_1.png \
382         ${xml_image_dir}/pbds_different_underlying_dss_2.png \
383         ${xml_image_dir}/pbds_embedded_lists_1.png \
384         ${xml_image_dir}/pbds_embedded_lists_2.png \
385         ${xml_image_dir}/pbds_embedded_lists_3.png \
386         ${xml_image_dir}/pbds_exception_hierarchy.png \
387         ${xml_image_dir}/pbds_hash_policy_cd.png \
388         ${xml_image_dir}/pbds_hash_ranged_hash_range_hashing_fns.png \
389         ${xml_image_dir}/pbds_hash_range_hashing_seq_diagram2.png \
390         ${xml_image_dir}/pbds_hash_range_hashing_seq_diagram.png \
391         ${xml_image_dir}/pbds_insert_resize_sequence_diagram1.png \
392         ${xml_image_dir}/pbds_insert_resize_sequence_diagram2.png \
393         ${xml_image_dir}/pbds_insert_resize_sequence_diagram3.png \
394         ${xml_image_dir}/pbds_invalidation_guarantee_erase.png \
395         ${xml_image_dir}/pbds_invalidation_tag_hierarchy.png \
396         ${xml_image_dir}/pbds_list_update.png \
397         ${xml_image_dir}/pbds_node_invariants.png \
398         ${xml_image_dir}/pbds_pat_trie.png \
399         ${xml_image_dir}/pbds_point_iterator_hierarchy.png \
400         ${xml_image_dir}/pbds_point_iterators_range_ops_1.png \
401         ${xml_image_dir}/pbds_point_iterators_range_ops_2.png \
402         ${xml_image_dir}/pbds_priority_queue_different_underlying_dss.png \
403         ${xml_image_dir}/pbds_priority_queue_tag_hierarchy.png \
404         ${xml_image_dir}/pbds_rationale_null_node_updator.png \
405         ${xml_image_dir}/pbds_resize_policy_cd.png \
406         ${xml_image_dir}/pbds_restoring_node_invariants.png \
407         ${xml_image_dir}/pbds_simple_list.png \
408         ${xml_image_dir}/pbds_tree_node_invalidations.png \
409         ${xml_image_dir}/pbds_tree_node_invariants.png \
410         ${xml_image_dir}/pbds_tree_node_updator_policy_cd.png \
411         ${xml_image_dir}/pbds_trie_node_updator_policy_cd.png \
412         ${xml_image_dir}/pbds_update_seq_diagram.png
414 xml_image_generated = \
415         ${xml_image_dir}/pbds_binary_priority_queue_int_push_pop.png \
416         ${xml_image_dir}/pbds_binary_priority_queue_int_push.png \
417         ${xml_image_dir}/pbds_ccgp_hash_int_subscript_insert.png \
418         ${xml_image_dir}/pbds_cc_hash_int_find.png \
419         ${xml_image_dir}/pbds_cc_hash_int_subscript_find.png \
420         ${xml_image_dir}/pbds_cc_hash_int_subscript_insert.png \
421         ${xml_image_dir}/pbds_gp_hash_int_find.png \
422         ${xml_image_dir}/pbds_gp_hash_int_subscript_find.png \
423         ${xml_image_dir}/pbds_gp_hash_int_subscript_insert.png \
424         ${xml_image_dir}/pbds_hash_int_erase_mem.png \
425         ${xml_image_dir}/pbds_hash_text_find.png \
426         ${xml_image_dir}/pbds_hash_zlob_int_find.png \
427         ${xml_image_dir}/pbds_multimap_text_find_large_s2p_hash.png \
428         ${xml_image_dir}/pbds_multimap_text_find_large_s2p_tree.png \
429         ${xml_image_dir}/pbds_multimap_text_find_small_s2p_hash.png \
430         ${xml_image_dir}/pbds_multimap_text_find_small_s2p_tree.png \
431         ${xml_image_dir}/pbds_multimap_text_insert_large_s2p_hash.png \
432         ${xml_image_dir}/pbds_multimap_text_insert_large_s2p_tree.png \
433         ${xml_image_dir}/pbds_multimap_text_insert_mem_large_s2p_hash.png \
434         ${xml_image_dir}/pbds_multimap_text_insert_mem_large_s2p_tree.png \
435         ${xml_image_dir}/pbds_multimap_text_insert_mem_small_s2p_hash.png \
436         ${xml_image_dir}/pbds_multimap_text_insert_mem_small_s2p_tree.png \
437         ${xml_image_dir}/pbds_multimap_text_insert_small_s2p_hash.png \
438         ${xml_image_dir}/pbds_multimap_text_insert_small_s2p_tree.png \
439         ${xml_image_dir}/pbds_pairing_priority_queue_text_modify_down_thin.png \
440         ${xml_image_dir}/pbds_pairing_priority_queue_text_modify_up_thin.png \
441         ${xml_image_dir}/pbds_pairing_priority_queue_text_push_pop.png \
442         ${xml_image_dir}/pbds_pairing_priority_queue_text_push.png \
443         ${xml_image_dir}/pbds_priority_queue_int_push_pop.png \
444         ${xml_image_dir}/pbds_priority_queue_int_push.png \
445         ${xml_image_dir}/pbds_priority_queue_text_join.png \
446         ${xml_image_dir}/pbds_priority_queue_text_modify_down.png \
447         ${xml_image_dir}/pbds_priority_queue_text_modify_up.png \
448         ${xml_image_dir}/pbds_priority_queue_text_pop_mem.png \
449         ${xml_image_dir}/pbds_priority_queue_text_push_pop.png \
450         ${xml_image_dir}/pbds_priority_queue_text_push.png \
451         ${xml_image_dir}/pbds_tree_int_find.png \
452         ${xml_image_dir}/pbds_tree_order_statistics.png \
453         ${xml_image_dir}/pbds_tree_split_join.png \
454         ${xml_image_dir}/pbds_tree_text_find.png \
455         ${xml_image_dir}/pbds_tree_text_insert_node.png \
456         ${xml_image_dir}/pbds_tree_text_insert_trie.png \
457         ${xml_image_dir}/pbds_tree_text_insert_vector.png \
458         ${xml_image_dir}/pbds_tree_text_lor_find.png
460 xml_images = ${xml_image_basic} ${xml_image_generated}
462 xml_noinst = \
463         ${xml_dir}/book.txml \
464         ${xml_dir}/chapter.txml \
465         ${xml_dir}/class.txml \
466         ${xml_image_dir}/confdeps.dot \
467         ${xml_image_dir}/confdeps.pdf
469 XSLTPROC       = xsltproc
470 XSLT_FLAGS = --nonet --xinclude
471 XSLT_PARAM = --param toc.section.depth 4 --param generate.consistent.ids 1
472 #XSL_STYLE_DIR = /usr/share/xml/docbook/stylesheet/docbook-xsl-ns
473 #XSL_STYLE_DIR = /usr/share/sgml/docbook/xsl-ns-stylesheets
474 XSL_FO_STYLE = $(XSL_STYLE_DIR)/fo/docbook.xsl
475 XSL_HTML_STYLE = $(XSL_STYLE_DIR)/xhtml/chunk.xsl
476 XSL_HTML_SINGLE_STYLE = $(XSL_STYLE_DIR)/html/docbook.xsl
477 XSL_EPUB_STYLE = $(XSL_STYLE_DIR)/epub3/chunk.xsl
478 XSL_LOCAL_STYLE = ${glibcxx_builddir}/doc/xsl/customization.xsl
480 ${docbook_outdir}/epub:
481         mkdir -p ${docbook_outdir}/epub
482         mkdir -p ${docbook_outdir}/epub/OEBPS/images
484 ${docbook_outdir}/fo:
485         mkdir -p ${docbook_outdir}/fo
487 ${docbook_outdir}/html:
488         mkdir -p ${docbook_outdir}/html
489         mkdir -p ${docbook_outdir}/html/images
490         mkdir -p ${docbook_outdir}/html/manual
492 ${docbook_outdir}/pdf:
493         mkdir -p ${docbook_outdir}/pdf
495 ${docbook_outdir}/latex:
496         mkdir -p ${docbook_outdir}/latex
498 ${docbook_outdir}/texinfo:
499         mkdir -p ${docbook_outdir}/texinfo
501 ${docbook_outdir}/xml:
502         mkdir -p ${docbook_outdir}/xml
505 # XML, all one page
506 # Some info on canonicalization
507 # http://www.mail-archive.com/help-texinfo@gnu.org/msg00864.html
508 manual_xml = ${docbook_outdir}/xml/libstdc++-manual.xml
509 set_xml = ${docbook_outdir}/xml/libstdc++-set.xml
510 stamp-xml-single-docbook: $(xml_sources) ${docbook_outdir}/xml
511         @echo "Generating XML single..."
512         $(XMLLINT) $(XMLLINT_FLAGS) \
513         ${top_srcdir}/doc/xml/manual/spine.xml > ${manual_xml};
514         $(XMLLINT) $(XMLLINT_FLAGS) \
515         ${top_srcdir}/doc/xml/spine.xml > ${set_xml};
516         $(STAMP) stamp-xml-single-docbook
518 doc-xml-single-docbook: stamp-xml-single-docbook
520 # Validate existing XML structure.
521 XMLLINT = xmllint
522 LINT_FLAGS = --debug --xinclude --noent --noblanks --noout
523 SCHEMA_FLAGS = --dtdvalid http://www.docbook.org/xml/5.0/dtd/docbook.dtd
524 SCHEMA_RNG_FLAGS = --relaxng http://www.docbook.org/xml/5.0/rng/docbook.rng
525 #SCHEMA_FLAGS = --nonet --dtdvalid /usr/share/xxx/dtd/5.0/docbook.dtd
526 XMLLINT_VALID_FLAGS = $(LINT_FLAGS) $(SCHEMA_FLAGS)
527 XMLLINT_FLAGS = --xinclude --nsclean --c14n --noent --noblanks --nocdata
528 doc-xml-validate-docbook: doc-xml-validate-dtd-db
530 doc-xml-validate-dtd-db: $(xml_sources) $(xml_images)
531         @echo "Generating XML validation log..."
532         $(XMLLINT) $(XMLLINT_VALID_FLAGS) ${top_srcdir}/doc/xml/spine.xml
534 doc-xml-validate-rng-db: $(xml_sources) $(xml_images) doc-xml-single-docbook
535         @echo "Generating XML RelaxNG validation log..."
536         $(XMLLINT) $(LINT_FLAGS) $(SCHEMA_RNG_FLAGS) ${set_xml}
538 # HTML support files
539 stamp-html-docbook-images: stamp-html-docbook $(xml_images)
540         $(INSTALL_DATA) $(xml_images) ${docbook_outdir}/html/images
541         $(STAMP) stamp-html-docbook-images
543 stamp-html-docbook-data: stamp-html-docbook-images
544         $(STAMP) stamp-html-docbook-data
546 # HTML, "chunked" into index plus chapters as separate pages
547 stamp-html-docbook: $(xml_sources) ${docbook_outdir}/html
548         @echo "Generating html files..."
549         $(XSLTPROC) $(XSLT_PARAM) $(XSLT_FLAGS) -o ${docbook_outdir}/html/ \
550          --stringparam chunker.output.encoding UTF-8 \
551         $(XSL_HTML_STYLE) \
552         ${top_srcdir}/doc/xml/spine.xml
553         $(STAMP) stamp-html-docbook
555 doc-html-docbook: stamp-html-docbook-data
557 # Generate the HTML pages and copy them back to the source tree.
558 doc-html-docbook-regenerate: doc-html-docbook
559         $(INSTALL_DATA) ${docbook_outdir}/html/*.html ${top_srcdir}/doc/html
560         $(INSTALL_DATA) ${docbook_outdir}/html/images/* ${top_srcdir}/doc/html/images
561         $(INSTALL_DATA) ${docbook_outdir}/html/manual/*.html ${top_srcdir}/doc/html/manual
563 # HTML, all one page
564 # NB: Have to generate customization XSL for UTF-8 output.
565 manual_html = ${docbook_outdir}/html/libstdc++-manual-single.html
566 stamp-html-single-docbook: $(xml_sources) ${docbook_outdir}/html
567         @echo "Generating html single file..."
568         $(XSLTPROC) $(XSLT_PARAM) $(XSLT_FLAGS) -o ${manual_html} \
569         ${XSL_LOCAL_STYLE} \
570         ${top_srcdir}/doc/xml/spine.xml
571         $(STAMP) stamp-html-single-docbook
573 doc-html-single-docbook: stamp-html-single-docbook
575 # FO
576 stamp-fo-docbook: $(xml_sources) ${docbook_outdir}/fo
577         @echo "Generating FO files..."
578         $(XSLTPROC) $(XSLT_FLAGS) -o ${docbook_outdir}/fo/spine.fo \
579         $(XSL_FO_STYLE) ${top_srcdir}/doc/xml/spine.xml
580         $(STAMP) stamp-fo-docbook
582 doc-fo-docbook: stamp-fo-docbook
584 # PDF, via dblatex
585 manual_pdf = ${docbook_outdir}/pdf/libstdc++-manual.pdf
586 DBLATEX_FLAGS = --verbose --pdf --dump --debug --tmpdir=${docbook_outdir}/latex
588 doc-pdf-docbook-dirs: ${docbook_outdir}/pdf ${docbook_outdir}/latex
590 doc-pdf-docbook-pre: $(xml_sources) doc-pdf-docbook-dirs
592 stamp-pdf-docbook: doc-pdf-docbook-pre doc-xml-single-docbook
593         @echo "Generating pdf dblatex files..."
594         dblatex $(DBLATEX_FLAGS) -o ${manual_pdf} \
595         ${top_srcdir}/doc/xml/spine.xml
596         $(STAMP) stamp-pdf-docbook
598 doc-pdf-docbook: stamp-pdf-docbook
600 # TEXINFO, via docbook2X
601 # NB: Both experimental and temperamental
602 manual_texi = ${docbook_outdir}/texinfo/libstdc++-manual.texi
603 manual_info = ${docbook_outdir}/texinfo/libstdc++-manual.info
604 DB2TEXI_FLAGS = \
605         --encoding=utf-8//TRANSLIT \
606         --string-param output-file="libstdc++-manual" \
607         --string-param directory-category="GNU C++ Library" \
608         --string-param explicit-node-names=true
610 stamp-texinfo-docbook: stamp-xml-single-docbook ${docbook_outdir}/texinfo
611         @echo "Generating texinfo files..."
612         db2x_docbook2texi $(DB2TEXI_FLAGS) ${set_xml}
613         mv libstdc++-manual.texi ${manual_texi}
614         $(STAMP) stamp-texinfo-docbook
616 stamp-info-docbook: stamp-texinfo-docbook
617         @echo "Generating info files..."
618         $(MAKEINFO) $(MAKEINFOFLAGS) ${manual_texi} -o ${manual_info}
619         $(STAMP) stamp-info-docbook
621 doc-texinfo-docbook: stamp-texinfo-docbook
623 doc-info-docbook: stamp-info-docbook
625 # EPUB version 3
626 # http://sourceforge.net/projects/docbook/files/epub3/
627 # Can verify document with epubcheck
628 manual_epub = ${docbook_outdir}/epub/libstdc++-manual.epub
629 stamp-epub-docbook: stamp-xml-single-docbook ${docbook_outdir}/epub
630         @echo "Generating epub files..."
631         if [ ! -d "${docbook_outdir}/images" ]; then \
632           $(LN_S) ${top_srcdir}/doc/xml/images ${docbook_outdir}/; \
633         fi
634         $(XSLTPROC) $(XSLT_PARAM) $(XSLT_FLAGS) \
635         --stringparam base.dir "${docbook_outdir}/epub/OEBPS/" \
636         $(XSL_EPUB_STYLE) ${top_srcdir}/doc/xml/spine.xml
637         $(INSTALL_DATA) $(xml_images) ${docbook_outdir}/epub/OEBPS/images
638         zip -X0 ${manual_epub} ${docbook_outdir}/epub/mimetype
639         zip -r -X9 ${manual_epub} ${docbook_outdir}/epub/META-INF ${docbook_outdir}/epub/OEBPS
640         $(STAMP) stamp-epub-docbook
642 doc-epub-docbook: stamp-epub-docbook
644 # Performance doc and graph configuration.
645 # Assumes pychart, beautiful soup installed.
646 # Generates the plots/graph imagery for performance testing.
647 doc_performance_script=${top_srcdir}/scripts/make_graph.py
648 doc-svg-performance: ${docbook_outdir}/xml
649         -@(chmod + ${doc_performance_script}; \
650         ${doc_performance_script} \
651         ${top_srcdir}/testsuite/data/make_graph_test_infos.xml \
652         ${glibcxx_builddir}/testsuite \
653         ${glibcxx_builddir}/doc/docbook/xml/images)
655 .PHONY: doc-doxygen-html doc-doxygen-man doc-performance
657 # By adding these files here, automake will remove them for 'make clean'
658 CLEANFILES = *.log stamp*
660 # To remove directories.
661 clean-local:
662         rm -rf man html pdf fo xml doxygen docbook ./libstdc++-* db2t*