X-Git-Url: http://git.draconx.ca/gitweb/rrace.git/blobdiff_plain/e9ab90141032c23a97fa82a723a7a751658bce66..0638562c931293881c645e7ddba35916d626b4ca:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 48a0b4e..c736530 100644 --- a/Makefile.am +++ b/Makefile.am @@ -12,18 +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) -bin_PROGRAMS = rrace-motif +if HAVE_CURSES +bin_PROGRAMS += rrace-curses +endif -rrace_motif_SOURCES = src/game.c src/x11.c +if HAVE_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/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) @@ -32,15 +54,15 @@ $(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 +libglohelp_a_SOURCES = common/src/help.c common/src/help.h 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 $@ @@ -48,26 +70,114 @@ $(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 $(GUIFILES) - -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/rng-test +check_PROGRAMS = t/boardmove t/boardbit t/ewmhicon t/rng-test +EXTRA_DIST += t/xos256ss.c -t_boardmove_LDADD = src/game.$(OBJEXT) libgnu.a +t_boardmove_SOURCES = t/boardmove.c src/game.c +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 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) + +SUFFIXES = .xpm .gen +XPMICONS = data/rr16x16.xpm data/rr24x24.xpm data/rr32x32.xpm data/rr48x48.xpm +PNGICONS = $(XPMICONS:.xpm=.png) + +DISTCLEANFILES += $(XPMICONS) +MAINTAINERCLEANFILES += $(PNGICONS) + +$(XPMICONS): t/ewmhicon$(EXEEXT) + $(AM_V_GEN) $(MKDIR_P) $(@D) + $(AM_V_at) s=`expr $(@F) : '[^0-9]*\([^.]*\)'`; \ + 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) $? | $(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 +.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 $(PNGICONS); do \ + if test -f "$$f"; \ + then cp "$$f" "$(distdir)/data" || exit; \ + else cp "$(srcdir)/$$f" "$(distdir)/data" || exit; \ + fi; done +.PHONY: dist-icons + +iconsdir = $(datarootdir)/icons/hicolor + +install-data-local: install-icons +install-icons: build-icons + for f in $(GENICONS); do \ + s=`expr "$$f" : '[^0-9]*\([^.]*\)'`; \ + od="$(DESTDIR)$(iconsdir)/$$s/apps"; \ + $(MKDIR_P) "$$od"; if test -f "$$f"; \ + then $(INSTALL_DATA) "$$f" "$$od/$(PACKAGE_TARNAME).png"; \ + else $(INSTALL_DATA) "$(srcdir)/$$f" "$$od/$(PACKAGE_TARNAME).png";\ + fi; done +.PHONY: install-icons + +uninstall-local: uninstall-icons +uninstall-icons: + for f in $(GENICONS); do \ + s=`expr "$$f" : '[^0-9]*\([^.]*\)'`; \ + od="$(DESTDIR)$(iconsdir)/$$s/apps"; \ + rm -f "$$od/$(PACKAGE_TARNAME).png"; \ + done +.PHONY: uninstall-icons + include $(top_srcdir)/lib/gnulib.mk include $(top_srcdir)/common/snippet/autotest.mk