Text Blame History Raw

Copyright (C) 2001-2003, 2005-2015 Free Software Foundation, Inc.

This program is free software: you can redistribute it and/or modify

it under the terms of the GNU General Public License as published by

the Free Software Foundation, either version 3 of the License, or

(at your option) any later version.

This program is distributed in the hope that it will be useful,

but WITHOUT ANY WARRANTY; without even the implied warranty of

MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the

GNU General Public License for more details.

You should have received a copy of the GNU General Public License

along with this program. If not, see http://www.gnu.org/licenses/.

AM_MAKEINFOFLAGS = --no-split info_TEXINFOS = doc/bison.texi doc_bison_TEXINFOS = \ $(CROSS_OPTIONS_TEXI) \ doc/fdl.texi \ doc/gpl-3.0.texi

Cannot express dependencies directly on file names because of Automake.

Obfuscate with a variable.

doc_bison = doc/bison $(doc_bison).dvi: $(FIGS_GV:.gv=.eps) $(doc_bison).info: $(FIGS_GV:.gv=.txt) $(doc_bison).pdf: $(FIGS_GV:.gv=.pdf) $(doc_bison).html: $(FIGS_GV:.gv=.png)

TEXI2DVI = texi2dvi --build-dir=doc/bison.t2d -I doc CLEANDIRS = doc/bison.t2d clean-local: rm -rf $(CLEANDIRS)

MOSTLYCLEANFILES += $(top_srcdir)/doc/*.t

CROSS_OPTIONS_PL = $(top_srcdir)/build-aux/cross-options.pl CROSS_OPTIONS_TEXI = $(top_srcdir)/doc/cross-options.texi $(CROSS_OPTIONS_TEXI): doc/bison.help $(CROSS_OPTIONS_PL)

Create $@~ which is the previous contents. Don't use 'mv' here so

that even if we are interrupted, the file is still available for

diff in the next run. Note that $@ might not exist yet.

$(AM_V_GEN){ test ! -f $@ || cat $@; } >$@~
$(AM_V_at)test ! -f $@.tmp || rm -f $@.tmp
$(AM_V_at)src/bison$(EXEEXT) --help |                \
  $(PERL) $(CROSS_OPTIONS_PL) $(top_srcdir)/src/scan-gram.l >$@.tmp
$(AM_V_at)diff -u $@~ $@.tmp || true
$(AM_V_at)mv $@.tmp $@

MAINTAINERCLEANFILES = $(CROSS_OPTIONS_TEXI)

----------

Ref card.

----------

EXTRA_DIST += doc/refcard.tex CLEANFILES += doc/refcard.pdf

doc/refcard.pdf: doc/refcard.tex $(AM_V_GEN) cd doc && pdftex $(abs_top_srcdir)/doc/refcard.tex

----------------

doc/bison.help.

----------------

Some of our targets (cross-option.texi, bison.1) use "bison --help".

Since we want to ship the generated file to avoid additional

requirements over the user environment, we used not depend on

src/bison itself, but on src/getargs.c and other files. Yet, we

need "bison --help" to work to make help2man happy, so we used to

include "make src/bison" in the commands. Then we may have a

problem with concurrent builds, since one make might be aiming one

of its jobs at compiling src/bison, and another job at generating

the man page. If the latter is faster than the former, then we have

two makes that concurrently try to compile src/bison. Doomed to

failure.

As a simple scheme to get our way out, make a stamp file,

bison.help, which contains --version then --help. This file can

depend on bison, which ensures its correctness. But update it

only if needed (content changes). This way, we avoid useless

compilations of cross-option.texi and bison.1. At the cost of

repeated builds of bison.help.

EXTRA_DIST += $(top_srcdir)/doc/bison.help if ! CROSS_COMPILING MAINTAINERCLEANFILES += $(top_srcdir)/doc/bison.help $(top_srcdir)/doc/bison.help: src/bison$(EXEEXT) $(AM_V_GEN)src/bison$(EXEEXT) --version >doc/bison.help.tmp $(AM_V_at) src/bison$(EXEEXT) --help >>doc/bison.help.tmp $(AM_V_at)$(top_srcdir)/build-aux/move-if-change doc/bison.help.tmp $@ endif ! CROSS_COMPILING

-----------

Man Pages.

-----------

dist_man_MANS = $(top_srcdir)/doc/bison.1

EXTRA_DIST += $(dist_man_MANS:.1=.x) MAINTAINERCLEANFILES += $(dist_man_MANS)

Differences to ignore when comparing the man page (the date).

remove_time_stamp = \ sed 's/^(.TH[^"]"[^"]"[^"])"[^"]"/\1/'

Depend on configure to get version number changes.

if ! CROSS_COMPILING MAN_DEPS = doc/bison.help doc/bison.x $(top_srcdir)/configure endif

$(top_srcdir)/doc/bison.1: $(MAN_DEPS) $(AM_V_GEN)$(HELP2MAN) \ --include=$(top_srcdir)/doc/bison.x \ --output=$@.t src/bison$(EXEEXT) $(AM_V_at)if $(remove_time_stamp) $@ >$@a.t 2>/dev/null && \ $(remove_time_stamp) $@.t | cmp $@a.t - >/dev/null 2>&1; then \ touch $@; \ else \ mv $@.t $@; \ fi $(AM_V_at)rm -f $@*.t

if ENABLE_YACC nodist_man_MANS = doc/yacc.1 endif

-----------------------------

Graphviz examples generation.

-----------------------------

CLEANFILES += $(FIGS_GV:.gv=.eps) $(FIGS_GV:.gv=.pdf) $(FIGS_GV:.gv=.png) FIGS_GV = \ doc/figs/example.gv \ doc/figs/example-reduce.gv doc/figs/example-shift.gv EXTRA_DIST += \ $(FIGS_GV) $(FIGS_GV:.gv=.txt) \ $(FIGS_GV:.gv=.eps) $(FIGS_GV:.gv=.pdf) $(FIGS_GV:.gv=.png) SUFFIXES += .gv .eps .pdf .png

.gv.eps: $(AM_V_GEN) $(MKDIR_P) echo "./$@" | sed -e 's,/[^/]*$$,,' $(AM_V_at) $(DOT) -Gmargin=0 -Teps $< >$@.tmp $(AM_V_at) mv $@.tmp $@

.gv.pdf: $(AM_V_GEN) $(MKDIR_P) echo "./$@" | sed -e 's,/[^/]*$$,,' $(AM_V_at) $(DOT) -Gmargin=0 -Tpdf $< >$@.tmp $(AM_V_at) mv $@.tmp $@

.gv.png: $(AM_V_GEN) $(MKDIR_P) echo "./$@" | sed -e 's,/[^/]*$$,,' $(AM_V_at) $(DOT) -Gmargin=0 -Tpng $< >$@.tmp $(AM_V_at) mv $@.tmp $@

--------------

Doxygenation.

--------------

DOXYGEN = doxygen

.PHONY: doc html

doc: html

html-local: doc/Doxyfile $(AM_V_GEN) $(DOXYGEN) doc/Doxyfile

edit = sed -e 's,@PACKAGE_NAME\@,$(PACKAGE_NAME),g' \ -e 's,@PACKAGE_VERSION\@,$(PACKAGE_VERSION),g' \ -e 's,@PERL\@,$(PERL),g' \ -e 's,@top_builddir\@,$(top_builddir),g' \ -e 's,@top_srcdir\@,$(top_srcdir),g'

EXTRA_DIST += doc/Doxyfile.in CLEANFILES += doc/Doxyfile

Sed is used to generate Doxyfile from Doxyfile.in instead of

configure, because the former is way faster than the latter.

doc/Doxyfile: $(top_srcdir)/doc/Doxyfile.in $(AM_V_GEN) $(edit) $(top_srcdir)/doc/Doxyfile.in >doc/Doxyfile

CLEANDIRS += doc/html