X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/ce6fc53682acb605e6358e22b5eccf4780a61a22..daa6f0b3f99dc3f84d094276242189c86362cd4b:/Makefile.am diff --git a/Makefile.am b/Makefile.am index ea3330c..e40e69c 100644 --- a/Makefile.am +++ b/Makefile.am @@ -17,12 +17,16 @@ AM_CPPFLAGS = -I$(top_builddir)/src -I$(top_srcdir)/src \ -DBISON_LOCALEDIR=\"$(BISON_LOCALEDIR)\" \ -DLOCALEDIR=\"$(localedir)\" +AM_CFLAGS = $(GSL_CFLAGS) + 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 +34,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 +49,24 @@ libcdecl_la_LIBADD = libgnu.la $(LTLIBINTL) $(LTLIBTHREAD) $(libcdecl_la_OBJECTS): $(gnulib_headers) bin_PROGRAMS = cdecl99 + +check_PROGRAMS = +EXTRA_LTLIBRARIES = libtest.la +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 @@ -56,6 +74,7 @@ src/typemap.lo: src/validtypes.h src/error.lo: src/errtab.h src/normalize.lo: src/ordspecs.h src/output.lo: src/namespecs.h +test/declgen.lo: test/typegen.h src/validtypes.h: $(srcdir)/src/types.lst $(srcdir)/src/validtypes.sed $(AM_V_GEN)sed -f $(srcdir)/src/validtypes.sed \ @@ -77,6 +96,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) @@ -104,10 +128,10 @@ install-mo: $(MOFILES) lang=`expr "$$mo" : '.*/\(.*\)\.mo' \| "$$mo" : '\(.*\)\.mo'`; \ test x"$$lang" = x"" && exit 1; \ inst="$(DESTDIR)$(localedir)/$$lang/LC_MESSAGES"; \ - set -x; \ - $(MKDIR_P) "$$inst" || exit $$?; \ - $(INSTALL_DATA) "$$mo" "$$inst/$(PACKAGE).mo" || exit $$?; \ - set +x; \ + (set -x; $(MKDIR_P) "$$inst") \ + || exit $$?; \ + (set -x; $(INSTALL_DATA) "$$mo" "$$inst/$(PACKAGE).mo") \ + || exit $$?; \ done installdirs-local: installdirs-mo @@ -116,9 +140,7 @@ installdirs-mo: lang=`expr "$$mo" : '.*/\(.*\)\.mo' \| "$$mo" : '\(.*\)\.mo'`; \ test x"$$lang" = x"" && exit 1; \ inst="$(DESTDIR)$(localedir)/$$lang/LC_MESSAGES"; \ - set -x; \ - $(MKDIR_P) "$$inst" || exit $$?; \ - set +x; \ + (set -x; $(MKDIR_P) "$$inst") || exit $$?; \ done uninstall-local: uninstall-mo @@ -127,9 +149,7 @@ uninstall-mo: lang=`expr "$$mo" : '.*/\(.*\)\.mo' \| "$$mo" : '\(.*\)\.mo'`; \ test x"$$lang" = x"" && exit 1; \ inst="$(DESTDIR)$(localedir)/$$lang/LC_MESSAGES"; \ - set -x; \ - cd "$$inst" && rm -f '$(PACKAGE).mo'; \ - set +x; \ + (set -x; cd "$$inst" && rm -f '$(PACKAGE).mo'); \ done .PHONY: install-mo installdirs-mo uninstall-mo @@ -144,9 +164,20 @@ 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' +.PHONY: update-headers + +# 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 {} + +.PHONY: unfuck-distdir # Supporting rules for bison/flex.