]> git.draconx.ca Git - cdecl99.git/blobdiff - Makefile.am
Mark dist hooks as phony.
[cdecl99.git] / Makefile.am
index a6782d7c460cd08ea4056d21d423099658670fa0..e40e69c84c23dc26106baadd941de20ce7276516 100644 (file)
@@ -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,22 +49,43 @@ 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
 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 $@
+
 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
@@ -71,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)
@@ -98,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
@@ -110,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
@@ -121,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
@@ -138,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.