X-Git-Url: http://git.draconx.ca/gitweb/rrace.git/blobdiff_plain/8d65a2da164b109c520d21afd051e4347e194182..372c088b3d4a74b3f2b9881c9a1eb36028bf44e9:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 0566953..c3efff6 100644 --- a/Makefile.am +++ b/Makefile.am @@ -12,21 +12,40 @@ MAINTAINERCLEANFILES = MOSTLYCLEANFILES = DISTCLEANFILES = CLEANFILES = $(EXTRA_LIBRARIES) +bin_PROGRAMS = AM_CPPFLAGS = -I$(builddir)/src -I$(srcdir)/src -I$(DX_BASEDIR)/src \ -I$(builddir)/lib -I$(srcdir)/lib -AM_CFLAGS = $(MOTIF_CFLAGS) +AM_CFLAGS = $(CURSES_CFLAGS) $(MOTIF_CFLAGS) + +if HAVE_CURSES +bin_PROGRAMS += rrace-curses +endif if HAVE_MOTIF -bin_PROGRAMS = rrace-motif +bin_PROGRAMS += rrace-motif +man_MANS = doc/rrace-motif.1 endif +EXTRA_DIST += doc/rrace-motif.1 + +noinst_HEADERS = conf_post.h src/version.h + +rrace_curses_SOURCES = common/src/help.c src/game.c src/version.c +rrace_curses_LDADD = $(libcursesmain_a_OBJECTS) libgnu.a $(CURSES_LIBS) + rrace_motif_SOURCES = src/game.c src/x11.c src/game.h src/motif.h \ - src/ewmhicon.c src/ewmhicon.h + src/colour.h src/ewmhicon.c src/ewmhicon.h \ + src/version.c src/xcounter.c src/xcounter.h rrace_motif_LDADD = $(libmotifmain_a_OBJECTS) $(libmotifui_a_OBJECTS) \ - $(libglohelp_a_OBJECTS) libgnu.a $(MOTIF_LIBS) + $(libglohelp_a_OBJECTS) libgnu.a $(MOTIF_LIBS) \ + $(LIB_CLOCK_GETTIME) $(LIB_GETHRXTIME) $(rrace_motif_OBJECTS): $(gnulib_headers) +EXTRA_LIBRARIES += libcursesmain.a +libcursesmain_a_SOURCES = src/curses.c src/cursmenu.c src/cursesui.h +$(libcursesmain_a_OBJECTS): $(gnulib_headers) src/cursesopt.h src/cursmenu.h + EXTRA_LIBRARIES += libmotifmain.a libmotifmain_a_SOURCES = src/motif.c $(libmotifmain_a_OBJECTS): $(gnulib_headers) @@ -35,7 +54,7 @@ $(libmotifmain_a_OBJECTS): src/motifopt.h EXTRA_LIBRARIES += libmotifui.a libmotifui_a_SOURCES = src/motif_ui.c $(libmotifui_a_OBJECTS): $(gnulib_headers) -$(libmotifui_a_OBJECTS): src/motifgui.h src/motifstr.h +$(libmotifui_a_OBJECTS): src/motifgui.h EXTRA_LIBRARIES += libglohelp.a libglohelp_a_SOURCES = common/src/help.c common/src/help.h @@ -43,7 +62,7 @@ libglohelp_a_CFLAGS = -DHELP_GETOPT_LONG_ONLY $(libglohelp_a_OBJECTS): $(gnulib_headers) libglohelp_a_SHORTNAME = glo -OPTFILES = src/motifopt.opt +OPTFILES = src/cursesopt.opt src/motifopt.opt .opt.h: $(AM_V_GEN) $(AWK) -f $(DX_BASEDIR)/scripts/gen-options.awk $< >$@.tmp $(AM_V_at) mv -f $@.tmp $@ @@ -51,29 +70,34 @@ $(OPTFILES:.opt=.h): $(DX_BASEDIR)/scripts/gen-options.awk DISTCLEANFILES += $(OPTFILES:.opt=.h) EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-options.awk $(OPTFILES) -STRFILES = src/motifstr.str -.str.h: - $(AM_V_GEN) $(AWK) -f $(DX_BASEDIR)/scripts/gen-strtab.awk $< >$@.tmp - $(AM_V_at) mv -f $@.tmp $@ -$(STRFILES:.str=.h): $(DX_BASEDIR)/scripts/gen-strtab.awk -DISTCLEANFILES += $(STRFILES:.str=.h) -EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-strtab.awk $(STRFILES) - -GUIFILES = src/motifgui.dat +TREEFILES = src/cursmenu.dat src/motifgui.dat .dat.h: - $(AM_V_GEN) $(AWK) -f $(DX_BASEDIR)/scripts/gen-tree.awk $< >$@.tmp - $(AM_V_at) mv -f $@.tmp $@ -$(GUIFILES:.dat=.h): $(DX_BASEDIR)/scripts/gen-tree.awk -DISTCLEANFILES += $(GUIFILES:.dat=.h) -EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-tree.awk $(GUIFILES) - -check_PROGRAMS = t/boardmove t/ewmhicon t/rng-test + $(AM_V_GEN) :; { \ + $(AWK) -f $(DX_BASEDIR)/scripts/gen-tree.awk $< && \ + printf '%s\n' \ + 'sub(/^#&/, "\\&") == 0 { next }' \ + '{ has_strtab=1 } END { if (!has_strtab) { exit(0); } print "" }' \ + | $(AWK) -f - -f $(DX_BASEDIR)/scripts/gen-strtab.awk $<; \ + } >$@-t + $(AM_V_at) mv -f $@-t $@ +$(TREEFILES:.dat=.h): $(DX_BASEDIR)/scripts/gen-strtab.awk +EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-strtab.awk +$(TREEFILES:.dat=.h): $(DX_BASEDIR)/scripts/gen-tree.awk +EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-tree.awk +DISTCLEANFILES += $(TREEFILES:.dat=.h) +EXTRA_DIST += $(TREEFILES) + +check_PROGRAMS = t/boardmove t/boardbit t/ewmhicon t/rng-test EXTRA_DIST += t/xos256ss.c t_boardmove_SOURCES = t/boardmove.c src/game.c -t_boardmove_LDADD = libgnu.a +t_boardmove_LDADD = libgnu.a $(LIB_CLOCK_GETTIME) $(LIB_GETHRXTIME) $(t_boardmove_OBJECTS): $(gnulib_headers) +t_boardbit_SOURCES = t/boardbit.c +t_boardbit_LDADD = libgnu.a +$(t_boardbit_OBJECTS): $(gnulib_headers) + t_ewmhicon_SOURCES = t/ewmhicon.c src/ewmhicon.c common/src/help.c t_ewmhicon_LDADD = libgnu.a $(MOTIF_LIBS) $(t_ewmhicon_OBJECTS): $(gnulib_headers) @@ -81,42 +105,52 @@ $(t_ewmhicon_OBJECTS): $(gnulib_headers) t_rng_test_LDADD = libgnu.a $(t_rng_test_OBJECTS): $(gnulib_headers) -GENPNG_V = $(GENPNG_V_@AM_V@) -GENPNG_V_ = $(GENPNG_V_@AM_DEFAULT_V@) -GENPNG_V_0 = @printf ' %$(DX_ALIGN_V)s %s\n' 'GEN ' $*.png; +SUFFIXES = .xpm .gen +XPMICONS = data/rr16x16.xpm data/rr24x24.xpm data/rr32x32.xpm data/rr48x48.xpm +PNGICONS = $(XPMICONS:.xpm=.png) + +DISTCLEANFILES += $(XPMICONS) +MAINTAINERCLEANFILES += $(PNGICONS) -$(GENICONS:.png=.gen): - $(GENPNG_V) $(MKDIR_P) $(@D) +$(XPMICONS): t/ewmhicon$(EXEEXT) + $(AM_V_GEN) $(MKDIR_P) $(@D) $(AM_V_at) s=`expr $(@F) : '[^0-9]*\([^.]*\)'`; \ - t/ewmhicon$(EXEEXT) -c yrwyogbbg "$$s" >$*.xpm + t/ewmhicon$(EXEEXT) -c yrwyogbbg "$$s" >$*-t.xpm + $(AM_V_at) mv -f $*-t.xpm $@ + +GENERIC_V = $(GENERIC_V_@AM_V@) +GENERIC_V_ = $(GENERIC_V_@AM_DEFAULT_V@) +GENERIC_V_0 = @printf '%2.0s%$(DX_ALIGN_V)s %s\n' + +data/rr16x16.gen: data/rr16x16.xpm +data/rr24x24.gen: data/rr24x24.xpm +data/rr32x32.gen: data/rr32x32.xpm +data/rr48x48.gen: data/rr48x48.xpm +$(PNGICONS:.png=.gen): + $(GENERIC_V) : 'GENDIST ' $*.png; $(MKDIR_P) $(@D) if USE_NETPBM - $(AM_V_at) $(XPMTOPPM) $*.xpm | $(PNMTOPNG) >$*-t.png -else -if USE_CONVERT - $(AM_V_at) $(CONVERT) $*.xpm $*-t.png + $(AM_V_at) $(XPMTOPPM) $? | $(PNMTOPNG) >$*-t.png endif +if USE_CONVERT + $(AM_V_at) $(CONVERT) $? $*-t.png endif $(AM_V_at) $(OPTIPNG) -o7 -quiet $*-t.png $(AM_V_at) mv -f $*-t.png $*.png -MOSTLYCLEANFILES += $(GENICONS:.png=-t.png) -DISTCLEANFILES += $(GENICONS:.png=.xpm) -MAINTAINERCLEANFILES += $(GENICONS) -SUFFIXES = .gen - -GENICONS = data/rr48x48.png data/rr32x32.png data/rr24x24.png data/rr16x16.png -$(GENICONS): ; - -build-icons: t/ewmhicon$(EXEEXT) $(GENICONS) - $(AM_V_at) set x $(GENICONS:.png=); shift; for f; do shift; \ - test -f "$$f.png" || test -f "$(srcdir)/$$f.png" || \ - { set x "$$@" "$$f.gen"; shift; }; \ - done; $(MAKE) $(AM_MAKEFLAGS) "$$@" +.PHONY: $(PNGICONS:.png=.gen) + +build-icons: + $(AM_V_at) list=; \ + for i in $(PNGICONS:.png=); do \ + test -f $$i.png || test -f $(srcdir)/$$i.png \ + || list="$$list $$i.gen"; \ + done; \ + test x"$$list" = x || $(MAKE) $(AM_MAKEFLAGS) $$list .PHONY: build-icons dist-hook: dist-icons dist-icons: build-icons $(MKDIR_P) $(distdir)/data - for f in $(GENICONS); do \ + for f in $(PNGICONS); do \ if test -f "$$f"; \ then cp "$$f" "$(distdir)/data" || exit; \ else cp "$(srcdir)/$$f" "$(distdir)/data" || exit; \