X-Git-Url: http://git.draconx.ca/gitweb/rrace.git/blobdiff_plain/b39d19918b63b80d1f3b068d158fe43415b9d1b6..3ab770d56719dfac72cf49f9a002a3f6b332593c:/Makefile.am diff --git a/Makefile.am b/Makefile.am index cab8d28..d99c5d7 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 src/icon.h src/ewmhicon.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/icon.c \ + 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,76 +70,81 @@ $(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) + $(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_SOURCES = t/ewmhicon.c src/ewmhicon.c src/icon.c common/src/help.c t_ewmhicon_LDADD = libgnu.a $(MOTIF_LIBS) $(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; +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" >$(@:.xpm=.tmp) + $(AM_V_at) mv -f $(@:.xpm=.tmp) $@ + +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' + +.xpm.genpng: + $(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) "$$@" + +build-icons: + $(AM_V_at) list=; \ + for i in $(PNGICONS:.png=); do \ + test -f $$i.png || test -f $(srcdir)/$$i.png \ + || list="$$list $$i.genpng"; \ + 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; \