X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/7804af20a363ed8e94d6e700505870cb4f550730..c58a93b9b3e42eb3668d9217a35b66d47ac47d50:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 469f962..535eff8 100644 --- a/Makefile.am +++ b/Makefile.am @@ -20,9 +20,11 @@ AM_CPPFLAGS = -I$(top_builddir)/src -I$(top_srcdir)/src \ MAINTAINERCLEANFILES = src/scan.c src/scan.h src/scan.stamp \ src/parse.c src/parse.h src/parse.stamp -CLEANFILES = src/validtypes.h src/errtab.h +CLEANFILES = src/validtypes.h src/errtab.h src/namespecs.h src/ordspecs.h \ + test/typegen.h EXTRA_DIST = m4/gnulib-cache.m4 src/types.lst src/validtypes.sed \ + src/specs.lst src/namespecs.sed src/ordspecs.sed \ src/errors.lst src/strtab.sed \ src/parse.stamp src/scan.stamp \ COPYING.WTFPL2 @@ -30,8 +32,8 @@ EXTRA_DIST = m4/gnulib-cache.m4 src/types.lst src/validtypes.sed \ dist_man_MANS = doc/man/cdecl99.1 doc/man/libcdecl.3 include_HEADERS = src/cdecl.h -noinst_HEADERS = src/typemap.h src/output.h src/scan.h src/parse.h src/i18n.h \ - src/error.h +noinst_HEADERS = conf_post.h src/typemap.h src/output.h src/scan.h \ + src/parse.h src/i18n.h src/normalize.h src/error.h noinst_DATA = $(MOFILES) @@ -45,10 +47,25 @@ libcdecl_la_LIBADD = libgnu.la $(LTLIBINTL) $(LTLIBTHREAD) $(libcdecl_la_OBJECTS): $(gnulib_headers) bin_PROGRAMS = cdecl99 + +check_PROGRAMS = +EXTRA_LTLIBRARIES = libtest.la +libtest_la_CFLAGS = $(AM_CFLAGS) $(GSL_CFLAGS) +libtest_la_LIBADD = $(GSL_LIBS) +libtest_la_SOURCES = test/testlib.c + +if HAVE_GSL +libtest_la_SOURCES += test/declgen.c +check_PROGRAMS += test/randomdecl +endif + cdecl99_SOURCES = src/cdecl99.c cdecl99_LDADD = libcdecl.la libgnu.la $(LTLIBINTL) $(LTLIBREADLINE) $(cdecl99_OBJECTS): $(gnulib_headers) +test_randomdecl_LDADD = libcdecl.la libtest.la libgnu.la +$(test_randomdecl_OBJECTS): $(gnulib_headers) + src/parse.lo: src/scan.h src/scan.lo: src/parse.h src/parse-decl.lo: src/scan.h src/parse.h @@ -57,6 +74,10 @@ src/error.lo: src/errtab.h src/normalize.lo: src/ordspecs.h src/output.lo: src/namespecs.h +# This is gross. +declgen_o = test/libtest_la-declgen.lo +$(declgen_o): test/typegen.h + src/validtypes.h: $(srcdir)/src/types.lst $(srcdir)/src/validtypes.sed $(AM_V_GEN)sed -f $(srcdir)/src/validtypes.sed \ < $(srcdir)/src/types.lst > $@.tmp @@ -77,6 +98,11 @@ src/errtab.h: $(srcdir)/src/errors.lst $(srcdir)/src/strtab.sed < $(srcdir)/src/errors.lst > $@.tmp $(AM_V_at)mv -f $@.tmp $@ +test/typegen.h: $(srcdir)/src/types.lst $(srcdir)/test/typegen.sh + $(AM_V_GEN) $(SHELL) $(srcdir)/test/typegen.sh \ + < $(srcdir)/src/types.lst > $@.tmp + $(AM_V_at)mv -f $@.tmp $@ + # Supporting rules for gettext. ALL_MOFILES = $(POFILES:.po=.mo) EXTRA_DIST += po/$(PACKAGE).pot po/LINGUAS $(POFILES) $(ALL_MOFILES) @@ -140,10 +166,19 @@ src/parse.c src/parse.h: src/parse.stamp # up-to-date timestamps, otherwise make will try to update them in a fresh # VPATH build. dist-hook: update-headers -update-headers: +update-headers: unfuck-distdir touch -c '$(distdir)/src/scan.h' touch -c '$(distdir)/src/parse.h' +# When running "make dist" in a VPATH build with a read-only srcdir, Automake +# will produce a distribution with all files read-only. Moreover, the files +# are read-only in distdir when the dist hooks are run. This hook will +# manually fix up the permissions. All dist hooks that modify files in distdir +# should list unfuck-distdir as a prerequisite. +dist-hook: unfuck-distdir +unfuck-distdir: + find '$(distdir)' -type f -exec chmod u+w {} + + # Supporting rules for bison/flex. BISON_V = $(BISON_V_$(V))