X-Git-Url: http://git.draconx.ca/gitweb/rrace.git/blobdiff_plain/683ddffaa0940d7c8b792d790c617e6950ce7a1a..174f6502f73fa29e1102938029d7b9f59b245c1b:/Makefile.am diff --git a/Makefile.am b/Makefile.am index 96e7340..f64bb6d 100644 --- a/Makefile.am +++ b/Makefile.am @@ -9,32 +9,64 @@ ACLOCAL_AMFLAGS = -I m4 -I common/m4 EXTRA_DIST = EXTRA_LIBRARIES = MAINTAINERCLEANFILES = +MOSTLYCLEANFILES = DISTCLEANFILES = CLEANFILES = $(EXTRA_LIBRARIES) +bin_PROGRAMS = -AM_CPPFLAGS = -I$(DX_BASEDIR)/src -AM_CFLAGS = $(MOTIF_CFLAGS) +AM_CPPFLAGS = -I$(builddir)/src -I$(srcdir)/src -I$(DX_BASEDIR)/src \ + -I$(builddir)/lib -I$(srcdir)/lib +AM_CFLAGS = $(CURSES_CFLAGS) $(MOTIF_CFLAGS) -bin_PROGRAMS = rrace-motif +GNULIB = libgnu.a $(LIB_CLOCK_GETTIME) $(LIB_GETHRXTIME) $(LIB_HARD_LOCALE) \ + $(LIB_MBRTOWC) $(LIB_SETLOCALE_NULL) $(LTLIBICONV) $(LTLIBINTL) \ + $(LTLIBUNISTRING) +LDADD = $(GNULIB) -rrace_motif_SOURCES = #src/motif.c common/src/help.c +if HAVE_CURSES +bin_PROGRAMS += rrace-curses +endif + +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) $(CURSES_LIBS) $(GNULIB) + +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) $(MOTIF_LIBS) + $(libglohelp_a_OBJECTS) $(MOTIF_LIBS) $(GNULIB) +$(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): src/options.h +$(libmotifmain_a_OBJECTS): $(gnulib_headers) +$(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 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/options.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 $@ @@ -42,10 +74,138 @@ $(OPTFILES:.opt=.h): $(DX_BASEDIR)/scripts/gen-options.awk DISTCLEANFILES += $(OPTFILES:.opt=.h) EXTRA_DIST += $(DX_BASEDIR)/scripts/gen-options.awk $(OPTFILES) -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/boardbit \ + t/boardmove \ + t/boardrect \ + t/checkgoal \ + t/ewmhicon \ + t/rng-test +EXTRA_DIST += t/xos256ss.c + +t_boardbit_SOURCES = t/boardbit.c +$(t_boardbit_OBJECTS): $(gnulib_headers) + +t_boardmove_SOURCES = t/boardmove.c src/game.c +$(t_boardmove_OBJECTS): $(gnulib_headers) + +t_boardrect_SOURCES = t/boardrect.c common/src/tap.c common/src/tap.h +$(t_boardrect_OBJECTS): $(gnulib_headers) + +t_checkgoal_SOURCES = t/checkgoal.c src/game.c +$(t_checkgoal_OBJECTS): $(gnulib_headers) + +t_ewmhicon_SOURCES = t/ewmhicon.c src/ewmhicon.c src/icon.c common/src/help.c +t_ewmhicon_LDADD = $(MOTIF_LIBS) $(GNULIB) +$(t_ewmhicon_OBJECTS): $(gnulib_headers) + +$(t_rng_test_OBJECTS): $(gnulib_headers) + +XPMICONS_LOCOLOR = data/lo16x16.xpm data/lo32x32.xpm data/lo48x48.xpm +XPMICONS_HICOLOR = data/hi16x16.xpm data/hi24x24.xpm \ + data/hi32x32.xpm data/hi48x48.xpm + +XPMICONS = $(XPMICONS_LOCOLOR) $(XPMICONS_HICOLOR) +PNGICONS = $(XPMICONS:.xpm=.png) + +DISTCLEANFILES += $(XPMICONS) +MAINTAINERCLEANFILES += $(PNGICONS) + +$(XPMICONS_HICOLOR): t/ewmhicon$(EXEEXT) + $(AM_V_GEN) $(MKDIR_P) $(@D) + $(AM_V_at) s=`expr $(@F) : '[^0-9]*\([^.]*\)'`; \ + t/ewmhicon$(EXEEXT) -c yrwyogbbg "$$s" >$(@:.xpm=.tmp) + $(AM_V_at) mv -f $(@:.xpm=.tmp) $@ + +$(XPMICONS_LOCOLOR): t/ewmhicon$(EXEEXT) + $(AM_V_GEN) $(MKDIR_P) $(@D) + $(AM_V_at) s=`expr $(@F) : '[^0-9]*\([^.]*\)'`; \ + t/ewmhicon$(EXEEXT) --w32vga -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) $? | $(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 + +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 $(PNGICONS); do \ + if test -f "$$f"; \ + then cp "$$f" "$(distdir)/data" || exit; \ + else cp "$(srcdir)/$$f" "$(distdir)/data" || exit; \ + fi; done +.PHONY: dist-icons + +hicolordir = $(datarootdir)/icons/hicolor +locolordir = $(datarootdir)/icons/locolor + +install-data-local: install-icons +install-icons: build-icons + for f in $(PNGICONS); do \ + s=`expr "$$f" : '[^0-9]*\([^.]*\)'`; \ + od="$(hicolordir)"; case $$f in */lo*) od="$(locolordir)" ;; esac; \ + od="$(DESTDIR)$$od/$$s/apps"; test -f "$$f" || f="$(srcdir)/$$f"; \ + $(MKDIR_P) "$$od"; \ + $(INSTALL_DATA) "$$f" "$$od/$(PACKAGE_TARNAME).png"; \ + done +.PHONY: install-icons + +uninstall-local: uninstall-icons +uninstall-icons: + for f in $(PNGICONS); do \ + s=`expr "$$f" : '[^0-9]*\([^.]*\)'`; \ + od="$(hicolordir)"; case $$f in */lo*) od="$(locolordir)" ;; esac; \ + od="$(DESTDIR)$$od/$$s/apps"; \ + rm -f "$$od/$(PACKAGE_TARNAME).png"; \ + done +.PHONY: uninstall-icons + +installcheck = installcheck +$(installcheck): check-installed-icons +check-installed-icons: + $(GENERIC_V) : 'CHECK ' "$(DESTDIR)$(hicolordir)"; \ + cd "$(DESTDIR)$(hicolordir)" && \ + test `find -name $(PACKAGE_TARNAME).png | wc -l` -gt 0 + $(GENERIC_V) : 'CHECK ' "$(DESTDIR)$(locolordir)"; \ + cd "$(DESTDIR)$(locolordir)" && \ + test `find -name $(PACKAGE_TARNAME).png | wc -l` -gt 0 + +include $(top_srcdir)/lib/gnulib.mk +include $(top_srcdir)/common/snippet/autotest.mk