X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/c4d0ba7251867ee9bdb8466357cba5a9fa352b76..898aa30bfb038ffeca54d6dea95f0f80fbc08f7f:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 4fdf566..452e811 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,4 +1,4 @@ -# Copyright © 2011-2013, 2019-2023 Nick Bowler +# Copyright © 2011-2013, 2019-2024 Nick Bowler # # License WTFPL2: Do What The Fuck You Want To Public License, version 2. # This is free software: you are free to do what the fuck you want to. @@ -9,6 +9,7 @@ ACLOCAL_AMFLAGS = -I m4 -I common/m4 # For Gnulib MOSTLYCLEANFILES = EXTRA_LTLIBRARIES = +EXTRA_PROGRAMS = AM_CPPFLAGS = -I$(top_builddir)/src -I$(top_srcdir)/src \ -I$(top_builddir)/lib -I$(top_srcdir)/lib \ @@ -25,16 +26,31 @@ CLEANFILES = $(EXTRA_LTLIBRARIES) $(EXTRA_LIBRARIES) EXTRA_DIST = bootstrap $(DX_BASEDIR)/scripts/fix-gnulib.pl m4/gnulib-cache.m4 \ src/types.lst src/parse.y src/parse.stamp src/scan.l \ - src/scan.stamp COPYING.WTFPL2 README.md INSTALL + src/scan.stamp COPYING.WTFPL2 README.md INSTALL \ + tests/data/manyspec.gz tests/data/manydecl.gz dist_man_MANS = doc/cdecl99.1 doc/libcdecl.3 -include_HEADERS = src/cdecl.h noinst_HEADERS = conf_pre.h conf_post.h common/src/help.h common/src/tap.h \ - common/src/xtra.h src/scan.h src/parse.h t/declgen.h t/test.h + common/src/xtra.h src/cdecl.h src/intconv.h src/parse.h \ + src/scan.h src/thread-posix.h src/thread-stdc.h \ + src/thread-w32.h src/version.h t/declgen.h t/test.h noinst_DATA = $(MOFILES) +nodist_include_HEADERS = src/config/cdecl.h +src/config/cdecl.h: config.h src/cdecl.h $(DX_BASEDIR)/scripts/bake-config.awk + $(AM_V_GEN) $(AWK) -f $(DX_BASEDIR)/scripts/bake-config.awk \ + config.h $(srcdir)/src/cdecl.h >$@-t + $(AM_V_at) mv -f $@-t $@ +EXTRA_DIST += $(DX_BASEDIR)/scripts/bake-config.awk +CLEANFILES += src/config/cdecl.h + +# Hack to get Automake to emit a dirstamp rule, and use it in src/config/cdecl.h. +src/config/cdecl.h: src/config/$(am__dirstamp) +EXTRA_PROGRAMS += src/config/gl-dirstamp +src_config_gl_dirstamp_SOURCES = + shared_gl_objects = $(gnulib_symfiles:.glsym=.lo) static_gl_objects = $(gnulib_extra_objects:.lo=.@OBJEXT@) @@ -59,7 +75,7 @@ EXTRA_libgnu_a_DEPENDENCIES = $(static_gl_objects) dummy $(static_gl_objects): $(gnulib_headers) bin_PROGRAMS = cdecl99 -cdecl99_SOURCES = common/src/help.c src/commands.c src/cdecl99.h +cdecl99_SOURCES = common/src/help.c src/commands.c src/cdecl99.h src/getline.h EXTRA_cdecl99_DEPENDENCIES = $(libmain_a_OBJECTS) $(libexec_a_OBJECTS) cdecl99_LDADD = $(EXTRA_cdecl99_DEPENDENCIES) libcdecl.la libgnu.a \ $(LTLIBINTL) $(LTLIBREADLINE) @@ -81,7 +97,7 @@ $(libmain_a_OBJECTS): src/options.h check_PROGRAMS = t/crossparse t/normalize t/randomdecl t/rng-test check_LIBRARIES = libtest.a -libtest_a_SOURCES = t/testlib.c t/rng.c common/src/help.c +libtest_a_SOURCES = t/testlib.c t/rng.c common/src/help.c common/src/tap.c $(libtest_a_OBJECTS): $(gnulib_headers) TEST_LIBS = libtest.a libcdecl.la libgnu.a $(LDEXP_LIBM) @@ -100,6 +116,29 @@ t_rng_test_LDADD = $(TEST_LIBS) $(t_rng_test_OBJECTS): $(gnulib_headers) EXTRA_DIST += t/xos256p.c +check_PROGRAMS += t/rendertest +t_rendertest_LDADD = $(TEST_LIBS) +$(t_rendertest_OBJECTS): $(gnulib_headers) + +check_PROGRAMS += t/scantest +t_scantest_LDADD = src/scan.lo src/parse.lo src/keywords.lo $(TEST_LIBS) +$(t_scantest_OBJECTS): $(gnulib_headers) src/scan.h src/parse.h + +EXTRA_LTLIBRARIES += t/liberrtest.la +t_liberrtest_la_SOURCES = src/error.c t/errmemwrap.c +t_liberrtest_la_CPPFLAGS = $(AM_CPPFLAGS) -DTEST_MALLOC_HOOK +t_liberrtest_la_LDFLAGS = -no-undefined -avoid-version \ + -bindir '$(bindir)' -rpath '$(libdir)' +EXTRA_t_liberrtest_la_DEPENDENCIES = $(shared_gl_objects) +t_liberrtest_la_LIBADD = src/output.lo $(EXTRA_t_liberrtest_la_DEPENDENCIES) \ + $(LTLIBINTL) $(LIBTHREAD) +t_liberrtest_la_SHORTNAME = t +$(t_liberrtest_la_OBJECTS): $(gnulib_headers) + +check_PROGRAMS += t/errthread +t_errthread_LDADD = t/liberrtest.la libtest.a $(LIBMULTITHREAD) +$(t_errthread_OBJECTS): $(gnulib_headers) src/errmsg.h + src/error.lo: src/errmsg.h src/keywords.lo: src/parse.h src/output.lo: src/parse.h src/specstr.h @@ -110,9 +149,10 @@ t/declgen.$(OBJEXT): t/typegen.h t/cdeclerr.$(OBJEXT): src/errmsg.h check_PROGRAMS += t/cdeclerr -t_cdeclerr_SOURCES = common/src/tap.c t/cdeclerr.c -EXTRA_t_cdeclerr_DEPENDENCIES = src/error.lo $(shared_gl_objects) -t_cdeclerr_LDADD = $(EXTRA_t_cdeclerr_DEPENDENCIES) $(LIBTHREAD) +t_cdeclerr_SOURCES = t/cdeclerr.c +EXTRA_t_cdeclerr_DEPENDENCIES = src/error.lo src/output.lo $(shared_gl_objects) +t_cdeclerr_LDADD = $(EXTRA_t_cdeclerr_DEPENDENCIES) \ + libtest.a $(LTLIBINTL) $(LIBTHREAD) $(t_cdeclerr_OBJECTS): $(gnulib_headers) # Supporting rules for gettext. @@ -128,9 +168,9 @@ XGETTEXT_OPTS = -D $(builddir) -D $(srcdir) --from-code=utf-8 \ --keyword=_ --keyword=N_ --keyword=PN_:1c,2 po/$(PACKAGE).pot: $(SOURCES) - $(AM_V_at) $(MKDIR_P) $(@D) - $(AM_V_GEN) $(XGETTEXT) $(XGETTEXT_OPTS) -o $@.tmp $(SOURCES) - $(AM_V_at) mv -f $@.tmp $@ + $(AM_V_GEN) $(MKDIR_P) po + $(AM_V_at) $(XGETTEXT) $(XGETTEXT_OPTS) -o $@.tmp $(SOURCES) + $(AM_V_at) mv -f $@.tmp $@ # These are required to prevent the builtin lex/yacc rules from # superseding ours... @@ -313,21 +353,40 @@ V_GPERF_0 = @printf ' %$(DX_ALIGN_V)s %s\n' 'GPERF ' $@; GPERFFILES = src/execute.gperf src/keywords.gperf .gperf.c: $(V_GPERF) $(GPERF) $< >$@.tmp - $(AM_V_at) mv $@.tmp $@ + $(AM_V_at) $(AWK) -f $(srcdir)/src/gperf-wordwrap.awk $@.tmp >$@.t2 + $(AM_V_at) mv $@.t2 $@ + $(AM_V_at) rm -f $@.tmp MAINTAINERCLEANFILES += $(GPERFFILES:.gperf=.c) -EXTRA_DIST += $(GPERFFILES) +EXTRA_DIST += $(GPERFFILES) src/gperf-wordwrap.awk +$(GPERFFILES:.gperf=.c): $(srcdir)/src/gperf-wordwrap.awk atlocal: config.status - $(AM_V_GEN) :; { \ - printf ': "$${%s=%s}"\n' \ - AWK '$(AWK)' \ - EXEEXT '$(EXEEXT)' \ - check_PROGRAMS '$(check_PROGRAMS)' \ - ; } >$@.tmp + $(AM_V_GEN) $(AWK) $@.tmp \ + 'BEGIN{ for (i = 1; i < ARGC; i++) print ": \"$${" ARGV[i] "}\""; }' \ + 'AWK=$(AWK)' 'EXEEXT=$(EXEEXT)' 'check_PROGRAMS=$(check_PROGRAMS)' \ + 'host_os=$(host_os)' $(AM_V_at) mv -f $@.tmp $@ check_DATA = atlocal CLEANFILES += atlocal +# Note: to reliably test linking against the installed library we directly +# refer to the just-installed .la file, rather than more typical library flags +# (-Lfoo -lfoo). Otherwise libtool can pick up libcdecl.la from the current +# working directory which defeats the point of an install check. +EXTRA_PROGRAMS += t/installcheck +t_installcheck_CPPFLAGS = -I$(DESTDIR)$(includedir) +t_installcheck_LDADD = $(DESTDIR)$(libdir)/libcdecl.la +t_installcheck_CFLAGS = +t_installcheck_SHORTNAME = x + +installcheck-local: + rm -f t/installcheck$(EXEEXT) $(t_installcheck_OBJECTS) + $(MAKE) $(AM_MAKEFLAGS) t/installcheck$(EXEEXT) + t/installcheck$(EXEEXT) | diff - $(srcdir)/t/installcheck.exp +.PHONY: installcheck-local +EXTRA_DIST += t/installcheck.c t/installcheck.exp +CLEANFILES += t/installcheck$(EXEEXT) + include $(top_srcdir)/lib/gnulib.mk include $(top_srcdir)/common/snippet/glconfig.mk include $(top_srcdir)/common/snippet/autotest.mk