X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/29304fc079678aea4bd99f814c75a1345bc2df4e..7ec517ce4d3b660e64133c2e67ef7686daec74e2:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 2597f8a..1673167 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,4 +1,4 @@ -# Copyright © 2011-2013, 2019-2021 Nick Bowler +# Copyright © 2011-2013, 2019-2023 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. @@ -12,18 +12,16 @@ EXTRA_LTLIBRARIES = AM_CPPFLAGS = -I$(top_builddir)/src -I$(top_srcdir)/src \ -I$(top_builddir)/lib -I$(top_srcdir)/lib \ - -I$(top_builddir)/test \ + -I$(DX_BASEDIR)/src -I$(top_builddir)/t \ -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 DISTCLEANFILES = -CLEANFILES = $(EXTRA_LTLIBRARIES) +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 \ @@ -32,32 +30,50 @@ EXTRA_DIST = bootstrap $(DX_BASEDIR)/scripts/fix-gnulib.pl m4/gnulib-cache.m4 \ dist_man_MANS = doc/cdecl99.1 doc/libcdecl.3 include_HEADERS = src/cdecl.h -noinst_HEADERS = conf_pre.h conf_post.h src/scan.h src/parse.h \ - test/declgen.h test/test.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 noinst_DATA = $(MOFILES) +shared_gl_objects = $(gnulib_symfiles:.glsym=.lo) +static_gl_objects = $(gnulib_extra_objects:.lo=.@OBJEXT@) + lib_LTLIBRARIES = libcdecl.la -libcdecl_la_LDFLAGS = -export-symbols-regex '^cdecl_[[:lower:]]' \ +libcdecl_la_LDFLAGS = -export-symbols-regex '^cdecl_([[:lower:]]|_gl_)' \ -no-undefined -version-info 1:0:0 libcdecl_la_SOURCES = src/scan.c src/parse.c src/parse-decl.c src/output.c \ src/explain.c src/declare.c src/error.c src/normalize.c \ - src/cdecl-internal.h -libcdecl_la_LIBADD = libgnu.la $(LTLIBINTL) $(LTLIBTHREAD) + src/cdecl-internal.h src/errmsg.h +libcdecl_la_LIBADD = $(shared_gl_objects) $(LTLIBINTL) $(LIBTHREAD) +EXTRA_libcdecl_la_DEPENDENCIES = $(shared_gl_objects) $(libcdecl_la_OBJECTS): $(gnulib_headers) if USE_NLS libcdecl_la_SOURCES += src/i18n.c endif +EXTRA_LIBRARIES = libgnu.a +libgnu_a_SOURCES = +libgnu_a_SHORTNAME = s +libgnu_a_CFLAGS = $(AM_CFLAGS) +libgnu_a_LIBADD = $(static_gl_objects) +EXTRA_libgnu_a_SOURCES = $(libgnu_la_SOURCES) $(EXTRA_libgnu_la_SOURCES) + +EXTRA_libgnu_a_DEPENDENCIES = $(static_gl_objects) +dummy $(static_gl_objects): $(gnulib_headers) + bin_PROGRAMS = cdecl99 -cdecl99_SOURCES = src/commands.c src/cdecl99.h -cdecl99_LDADD = $(libmain_a_OBJECTS) $(libexec_a_OBJECTS) libcdecl.la \ - libgnu.la $(LTLIBICONV) $(LTLIBINTL) $(LTLIBREADLINE) +cdecl99_SOURCES = common/src/help.c src/commands.c src/cdecl99.h +EXTRA_cdecl99_DEPENDENCIES = $(libmain_a_OBJECTS) $(libexec_a_OBJECTS) +cdecl99_LDADD = $(EXTRA_cdecl99_DEPENDENCIES) libcdecl.la libgnu.a \ + $(LTLIBINTL) $(LTLIBREADLINE) $(cdecl99_OBJECTS): $(gnulib_headers) -$(cdecl99_OBJECTS): src/options.h -EXTRA_LIBRARIES = libexec.a +if USE_NLS +cdecl99_SOURCES += common/src/copysym.c common/src/copysym.h +endif + +EXTRA_LIBRARIES += libexec.a libexec_a_SOURCES = src/execute.c src/commands.h $(libexec_a_OBJECTS): $(gnulib_headers) $(libexec_a_OBJECTS): src/commands.h src/cmdlist.h @@ -67,30 +83,40 @@ libmain_a_SOURCES = src/cdecl99.c src/options.h $(libmain_a_OBJECTS): $(gnulib_headers) $(libmain_a_OBJECTS): src/options.h -check_PROGRAMS = test/crossparse test/normalize -check_LTLIBRARIES = libtest.la -libtest_la_LIBADD = $(GSL_LIBS) -libtest_la_SOURCES = test/testlib.c -$(libtest_la_OBJECTS): $(gnulib_headers) +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_OBJECTS): $(gnulib_headers) -if HAVE_GSL -libtest_la_SOURCES += test/declgen.c -check_PROGRAMS += test/randomdecl -endif +TEST_LIBS = libtest.a libcdecl.la libgnu.a $(LDEXP_LIBM) + +t_randomdecl_SOURCES = t/randomdecl.c t/declgen.c +t_randomdecl_LDADD = $(TEST_LIBS) +$(t_randomdecl_OBJECTS): $(gnulib_headers) + +t_crossparse_LDADD = $(TEST_LIBS) +$(t_crossparse_OBJECTS): $(gnulib_headers) + +t_normalize_LDADD = src/output.lo src/normalize.lo $(TEST_LIBS) +$(t_normalize_OBJECTS): $(gnulib_headers) -test_crossparse_LDADD = libtest.la libcdecl.la libgnu.la -$(test_crossparse_OBJECTS): $(gnulib_headers) -test_randomdecl_LDADD = libtest.la libcdecl.la libgnu.la -$(test_randomdecl_OBJECTS): $(gnulib_headers) -test_normalize_LDADD = libtest.la src/output.lo src/normalize.lo \ - libcdecl.la libgnu.la -$(test_normalize_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.h +t_rng_test_LDADD = $(TEST_LIBS) +$(t_rng_test_OBJECTS): $(gnulib_headers) +EXTRA_DIST += t/xos256p.c + +src/parse.lo: src/scan.h src/errmsg.h +src/scan.lo: src/parse.h src/errmsg.h +src/parse-decl.lo: src/scan.h src/parse.h src/typemap.h src/errmsg.h src/output.lo: src/specstr.h -test/declgen.lo: test/typegen.h +src/error.lo: src/errmsg.h +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_OBJECTS): $(gnulib_headers) # Supporting rules for gettext. include $(top_srcdir)/common/snippet/gettext.mk @@ -183,7 +209,7 @@ $(OPTFILES:.opt=.h): $(DX_BASEDIR)/scripts/gen-options.awk MAINTAINERCLEANFILES += $(OPTFILES:.opt=.h) EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-options.awk $(OPTFILES) -STRFILES = src/commands.str +STRFILES = src/commands.str src/errmsg.str .str.h: $(AM_V_GEN) $(AWK) -f $(DX_BASEDIR)/scripts/gen-strtab.awk $< >$@.tmp $(AM_V_at) mv -f $@.tmp $@ @@ -214,12 +240,12 @@ src/typemap.h: src/gen-typemap.awk src/types.lst DISTCLEANFILES += src/typemap.h EXTRA_DIST += src/gen-typemap.awk -test/typegen.h: test/gen-typegen.awk src/types.lst - $(AM_V_GEN) $(AWK) -f $(srcdir)/test/gen-typegen.awk \ +t/typegen.h: t/gen-typegen.awk src/types.lst + $(AM_V_GEN) $(AWK) -f $(srcdir)/t/gen-typegen.awk \ $(srcdir)/src/types.lst >$@.tmp $(AM_V_at) mv -f $@.tmp $@ -DISTCLEANFILES += test/typegen.h -EXTRA_DIST += test/gen-typegen.awk +DISTCLEANFILES += t/typegen.h +EXTRA_DIST += t/gen-typegen.awk # Supporting rules for bison/flex. @@ -279,6 +305,11 @@ endif $(MAKE) $(AM_MAKEFLAGS) $<; \ fi +GPERF = gperf +V_GPERF = $(V_GPERF_@AM_V@) +V_GPERF_ = $(V_GPERF_@AM_DEFAULT_V@) +V_GPERF_0 = @printf ' %$(DX_ALIGN_V)s %s\n' 'GPERF ' $@; + GPERFFILES = src/execute.gperf .gperf.c: $(V_GPERF) $(GPERF) $< >$@.tmp @@ -289,6 +320,7 @@ EXTRA_DIST += $(GPERFFILES) atlocal: config.status $(AM_V_GEN) :; { \ printf ': "$${%s=%s}"\n' \ + AWK '$(AWK)' \ EXEEXT '$(EXEEXT)' \ check_PROGRAMS '$(check_PROGRAMS)' \ ; } >$@.tmp