X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/b712f2d42fe47b7845026b2a3a1ea22569023dd6..568c39ad1836f8cf87ccc1b2ba577b6f6ba37e25:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 638b071..5781b23 100644 --- a/Makefile.am +++ b/Makefile.am @@ -20,10 +20,10 @@ 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/typenames.h src/validtypes.h src/errtab.h +CLEANFILES = src/validtypes.h src/errtab.h test/typegen.h -EXTRA_DIST = m4/gnulib-cache.m4 src/types.lst src/typenames.sed \ - src/validtypes.sed src/errors.lst src/strtab.sed \ +EXTRA_DIST = m4/gnulib-cache.m4 src/types.lst src/validtypes.sed \ + src/errors.lst src/strtab.sed \ src/parse.stamp src/scan.stamp \ COPYING.WTFPL2 @@ -39,39 +39,68 @@ lib_LTLIBRARIES = libcdecl.la libcdecl_la_LDFLAGS = -no-undefined \ -export-symbols-regex '^cdecl_[[:lower:]]' libcdecl_la_SOURCES = src/scan.c src/parse.c src/parse-decl.c src/typemap.c \ - src/output.c src/explain.c src/declare.c src/i18n.c src/error.c + src/output.c src/explain.c src/declare.c src/i18n.c src/error.c \ + src/normalize.c 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) -# Sources that may contain translatable strings. -POTSOURCES = $(SOURCES) src/errtab.h +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 -src/typemap.lo: src/validtypes.h src/typenames.h +src/typemap.lo: src/validtypes.h 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 $(AM_V_at)mv -f $@.tmp $@ -src/typenames.h: $(srcdir)/src/types.lst $(srcdir)/src/typenames.sed - $(AM_V_GEN)sed -f $(srcdir)/src/typenames.sed \ - < $(srcdir)/src/types.lst > $@.tmp - $(AM_V_at)mv -f $@.tmp $@ +src/namespecs.h: $(srcdir)/src/specs.lst $(srcdir)/src/namespecs.sed + $(AM_V_GEN) sed -f $(srcdir)/src/namespecs.sed \ + < $(srcdir)/src/specs.lst > $@.tmp + $(AM_V_at) mv -f $@.tmp $@ + +src/ordspecs.h: $(srcdir)/src/specs.lst $(srcdir)/src/ordspecs.sed + $(AM_V_GEN) sed -f $(srcdir)/src/ordspecs.sed \ + < $(srcdir)/src/specs.lst > $@.tmp + $(AM_V_at) mv -f $@.tmp $@ src/errtab.h: $(srcdir)/src/errors.lst $(srcdir)/src/strtab.sed - $(AM_V_GEN)sed -nf $(srcdir)/src/strtab.sed \ + $(AM_V_GEN)sed -f $(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) @@ -80,11 +109,14 @@ XGETTEXT_OPTS = -D $(builddir) -D $(srcdir) --from-code=utf-8 \ --add-comments=TRANSLATORS: --foreign-user \ --package-name=$(PACKAGE) --package-version=$(PACKAGE_VERSION) \ --msgid-bugs-address=$(PACKAGE_BUGREPORT) \ - --keyword=_ --keyword=N_ + --keyword=_ --keyword=N_ --keyword=PN_:1c,2 -po/$(PACKAGE).pot: $(POTSOURCES) - $(AM_V_at)$(MKDIR_P) $(@D) - $(AM_V_GEN)$(XGETTEXT) $(XGETTEXT_OPTS) -o $@ $(POTSOURCES) +po/$(PACKAGE).pot: $(SOURCES) src/errors.lst + $(AM_V_at) $(MKDIR_P) $(@D) + $(AM_V_GEN) $(XGETTEXT) $(XGETTEXT_OPTS) -o $@.tmp $(SOURCES) + $(AM_V_at) $(XGETTEXT) $(XGETTEXT_OPTS) --omit-header -Lc \ + -ajo $@.tmp src/errors.lst + $(AM_V_at) mv -f $@.tmp $@ .po.mo: $(AM_V_at)$(MKDIR_P) $(@D) @@ -96,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 @@ -108,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 @@ -119,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