Merge branch
[YACASL2.git] / Makefile
index b074511..e88b56f 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,71 +1,83 @@
-.PHONY: all build gtags check doc info html doc-inner install uninstall install-info uninstall-info install-casl2lib uninstall-casl2lib version gittag clean clean-src clean-gtags clean-test clean-doc clean-doc-inner
-
-CMD := casl2 comet2 dumpword
+.PHONY: all srcall gtags \
+        check valgrind \
+        doc alldoc doc_inner \
+        install uninstall \
+        version gittag \
+        clean src-clean gtags-clean \
+        test-clean doc-clean doc_inner-clean
 
 CAT := cat
-CP := cp
-ECHO := echo
-GITTAG := git tag
+CP := cp -v
+ECHO := /bin/echo
+EXPR := expr
+GIT := git
+GREP := grep
 GTAGS := gtags
 INSTALL := install
 SED := sed
+WC := wc
 WHICH := which
+XARGS := xargs
 
 prefix ?= ~
 bindir ?= $(prefix)/bin
+libdir ?= $(prefix)/share
+
+VERSION := $(shell $(CAT) VERSION)
+
+VERSIONGITREF := $(shell $(GIT) show-ref -s --tags $(VERSION))
 
-VERSION = $(shell $(CAT) VERSION)
-VERSIONFILES = include/package.h test/system/casl2/opt_v/0.txt test/system/comet2/opt_v/0.txt test/system/dumpword/opt_v/0.txt
+MASTERGITREF := $(shell $(GIT) show-ref -s refs/heads/master)
 
-all: build doc gtags
+VERSIONFILES := include/version.h \
+        test/system/casl2_opt/opt_v/0.txt \
+        test/system/comet2_opt/opt_v/0.txt \
+        test/system/dumpword/opt_v/0.txt
+
+CMDFILES := casl2 comet2 dumpword casl2rev comet2monitor
+
+all: build INSTALL gtags
 
 build: version
        $(MAKE) -C src all
-       $(CP) $(addprefix src/,$(CMD)) ./
+       @(for f in $(CMDFILES); do if test ! -e $$f -o src/$$f -nt $$f; then $(CP) src/$$f $$f; fi; done)
 
 gtags:
        $(if $(strip $(shell $(WHICH) $(GTAGS))),$(GTAGS),@$(ECHO) '$(GTAGS): not found')
 
-doc:
-       $(MAKE) -C doc base
-       $(MAKE) INSTALL
-
 INSTALL: doc/install.txt
        $(CP) $< $@
 
-docall:
-       $(MAKE) -C doc all
-
-info:
-       $(MAKE) -C doc info
+doc/install.txt:
+       $(MAKE) -C doc base
 
-html:
-       $(MAKE) -C doc html
+alldoc:
+       $(MAKE) -C doc all
 
-doc-inner:
+doc_inner:
        $(MAKE) -C doc_inner all
 
 check:
        $(MAKE) -sC test/system
 
-install: casl2 comet2 dumpword install-info install-casl2lib
+smoke:
+       $(MAKE) -sC test/system smoke
+
+smoke-valgrind:
+       $(MAKE) -sC test/system smoke-valgrind
+
+valgrind:
+       $(MAKE) -sC test/system valgrind
+
+install: casl2 comet2 dumpword install-info
        $(INSTALL) -d $(bindir)
        $(INSTALL) $(CMD) $(bindir)/
 
-uninstall: uninstall-info uninstall-casl2lib
-       $(RM) $(prefix $(bindir)/,$(CMD))
-
 install-info:
        $(MAKE) -C doc install-info
 
-uninstall-info:
-       $(MAKE) -C doc uninstall-info
-
-install-casl2lib:
-       $(MAKE) -C as/casl2lib install-casl2lib
-
-uninstall-casl2lib:
-       $(MAKE) -C as/casl2lib uninstall-casl2lib
+uninstall: uninstall-info
+       $(RM) $(prefix $(bindir)/,$(CMD))
 
 version: $(VERSIONFILES)
        @$(ECHO) "YACASL2 Version: $(VERSION)"
@@ -73,28 +85,33 @@ version: $(VERSIONFILES)
 $(VERSIONFILES): VERSION
        @$(SED) -e "s/@@VERSION@@/$(VERSION)/g" $@.version >$@
 
-gittag: VERSION
-       $(GITTAG) $(VERSION)
+gittag:
+       if test `$(GIT) status -s | $(WC) -l` -gt 0; then $(ECHO) "Error: commit, first."; exit 1; fi; if test "$(VERSIONGITREF)" != "$(MASTERGITREF)"; then $(GIT) tag $(VERSION); fi
+
+distclean: cmd-clean src-distclean gtags-clean version-clean clean
+
+clean: src-clean doc-clean doc_inner-clean
 
-clean: clean-cmd clean-src clean-gtags clean-doc clean-doc-inner clean-version
+cmd-clean:
+       $(RM) $(CMD)
 
-clean-cmd:
-       @$(RM) $(CMD)
+src-clean:
+       $(MAKE) -sC src clean
 
-clean-src:
-       @$(MAKE) -sC src clean
+src-distclean:
+       $(MAKE) -sC src distclean
 
-clean-gtags:
-       @$(RM) GPATH GRTAGS GSYMS GTAGS
+gtags-clean:
+       $(RM) GPATH GRTAGS GSYMS GTAGS
 
-clean-doc:
-       @$(MAKE) -sC doc clean
+doc-clean:
+       $(MAKE) -sC doc clean
 
-clean-doc-inner:
-       @$(MAKE) -sC doc_inner clean
+doc_inner-clean:
+       $(MAKE) -sC doc_inner clean
 
-clean-version:
-       @$(RM) $(VERSIONFILES)
+version-clean:
+       $(RM) $(VERSIONFILES)
 
-clean-test:
-       @$(MAKE) -sC test clean
+test-clean:
+       $(MAKE) -sC test clean