X-Git-Url: https://git.draconx.ca/gitweb/cdecl99.git/blobdiff_plain/55e350dc7050d5384f8d33a1583d6c8d8da4e1c3..438fd434fd51cc2bd17bbdc8a2eb945493a6baa7:/Makefile.am diff --git a/Makefile.am b/Makefile.am index d4d375f..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,51 +12,68 @@ 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 = src/validtypes.h src/namespecs.h src/ordspecs.h \ - test/typegen.h $(EXTRA_LTLIBRARIES) +CLEANFILES = $(EXTRA_LTLIBRARIES) $(EXTRA_LIBRARIES) EXTRA_DIST = bootstrap $(DX_BASEDIR)/scripts/fix-gnulib.pl m4/gnulib-cache.m4 \ - src/types.lst src/validtypes.sed src/specs.lst src/namespecs.sed \ - src/ordspecs.sed test/typegen.sh src/parse.y src/parse.stamp \ - src/scan.l src/scan.stamp COPYING.WTFPL2 README.md INSTALL + src/types.lst src/parse.y src/parse.stamp src/scan.l \ + src/scan.stamp COPYING.WTFPL2 README.md INSTALL -dist_man_MANS = doc/man/cdecl99.1 doc/man/libcdecl.3 +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:]]' \ - -no-undefined -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/normalize.c src/cdecl-internal.h \ - src/errtab.h -libcdecl_la_LIBADD = libgnu.la $(LTLIBINTL) $(LTLIBTHREAD) +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 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 @@ -66,50 +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 -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) -test_crossparse_LDADD = libcdecl.la libtest.la libgnu.la -$(test_crossparse_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 -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 \ - < $(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 $@ +t_randomdecl_SOURCES = t/randomdecl.c t/declgen.c +t_randomdecl_LDADD = $(TEST_LIBS) +$(t_randomdecl_OBJECTS): $(gnulib_headers) -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 $@ +t_crossparse_LDADD = $(TEST_LIBS) +$(t_crossparse_OBJECTS): $(gnulib_headers) -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 $@ +t_normalize_LDADD = src/output.lo src/normalize.lo $(TEST_LIBS) +$(t_normalize_OBJECTS): $(gnulib_headers) + +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 +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 @@ -202,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 src/errtab.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 $@ @@ -219,6 +226,27 @@ src/cmdlist.h: src/gen-cmdlist.awk src/execute.c DISTCLEANFILES += src/cmdlist.h EXTRA_DIST += src/gen-cmdlist.awk +src/specstr.h: src/gen-specstr.awk src/cdecl.h + $(AM_V_GEN) $(AWK) -f $(srcdir)/src/gen-specstr.awk \ + $(srcdir)/src/cdecl.h >$@.tmp + $(AM_V_at) mv -f $@.tmp $@ +DISTCLEANFILES += src/specstr.h +EXTRA_DIST += src/gen-specstr.awk + +src/typemap.h: src/gen-typemap.awk src/types.lst + $(AM_V_GEN) $(AWK) -f $(srcdir)/src/gen-typemap.awk \ + $(srcdir)/src/types.lst >$@.tmp + $(AM_V_at) mv -f $@.tmp $@ +DISTCLEANFILES += src/typemap.h +EXTRA_DIST += src/gen-typemap.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 += t/typegen.h +EXTRA_DIST += t/gen-typegen.awk + # Supporting rules for bison/flex. BISON_V = $(BISON_V_@AM_V@) @@ -277,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 @@ -287,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