Correction : compatiblité avec GHC-7.6 en limitant l’usage de Prelude.
[comptalang.git] / GNUmakefile
index 2c8180f4012c16652604ee6f46f361fce2e7298c..44c298b5c0c5a3aab44410303983879f9a9c7249 100644 (file)
@@ -16,8 +16,8 @@ GHC_PROF_PS_WIDTH:=11in
 GHC_PROF_RATE:=0.1
 GHC_PROF_CC_LENGTH:=50
 HCOMPTA_CLI_PROF:=$(CABAL_SANDBOX)/bin/hcompta-cli-prof
-HCOMPTA_COMMANDS:=balance
-# gl journal
+HCOMPTA_COMMANDS:=balance gl journal
+HCOMPTA_INTERFACES:=lib cli web
 commit:=$(shell if which git >/dev/null; then git describe --long; else echo COMMIT; fi)
 
 #
@@ -30,23 +30,27 @@ rmdirw=$(call if_arg,rmdir -p --ignore-fail-on-non-empty,$(wildcard $1))
 #
 ##  install
 ###
-install: cabal/install lib/install cli/install web/install
+install: cabal/install $(HCOMPTA_INTERFACES:=/install)
 cabal/install:
-       cabal update $(CABAL_FLAGS) $(CABAL_UPDATE_FLAGS)
-       cabal install -v $(CABAL_FLAGS) $(CABAL_INSTALL_FLAGS) cabal
-.PHONY: lib cli web
-lib lib/install:
-       cabal install -v --force-reinstalls $(CABAL_FLAGS) $(CABAL_INSTALL_FLAGS) ./lib
+       cabal $(CABAL_FLAGS) update $(CABAL_UPDATE_FLAGS)
+       cabal $(CABAL_FLAGS) install -v $(CABAL_INSTALL_FLAGS) cabal
+.PHONY: $(HCOMPTA_INTERFACES)
+lib lib/install: cli/unregister web/unregister cli/unregister/sandbox web/unregister/sandbox
+       cabal $(CABAL_FLAGS) install -v $(CABAL_INSTALL_FLAGS) ./lib
 cli cli/install:
-       cabal install -v --force-reinstalls $(CABAL_FLAGS) $(CABAL_INSTALL_FLAGS) ./cli
+       cabal $(CABAL_FLAGS) install -v $(CABAL_INSTALL_FLAGS) ./cli
 web web/install:
-       cabal install -v                    $(CABAL_FLAGS) $(CABAL_INSTALL_FLAGS) alex happy
-       cabal install -v --force-reinstalls $(CABAL_FLAGS) $(CABAL_INSTALL_FLAGS) ./web
+       cabal $(CABAL_FLAGS) install -v $(CABAL_INSTALL_FLAGS) alex happy
+       cabal $(CABAL_FLAGS) install -v $(CABAL_INSTALL_FLAGS) ./web
+
+%/recomp: CABAL_INSTALL_FLAGS+=--ghc-options -fforce-recomp
+%/recomp: %
+       
 
 #
 ##  clean
 ###
-clean: lib/clean cli/clean web/clean doc/clean
+clean: lib/clean $(HCOMPTA_INTERFACES:=/clean)
 lib/clean:
        (cd lib && cabal clean)
 cli/clean:
@@ -57,13 +61,13 @@ web/clean:
 #
 ##  test
 ###
-test: lib/test cli/test web/test
+test: $(HCOMPTA_INTERFACES:=/test)
 lib/test:
-       (cd lib && cabal test --show-details=always $(CABAL_FLAGS) $(CABAL_TEST_FLAGS))
+       (cd lib && cabal $(CABAL_FLAGS) test --show-details=always $(CABAL_TEST_FLAGS))
 cli/test:
-       (cd cli && cabal test --show-details=always $(CABAL_FLAGS) $(CABAL_TEST_FLAGS))
+       (cd cli && cabal $(CABAL_FLAGS) test --show-details=always $(CABAL_TEST_FLAGS))
 web/test:
-       (cd web && cabal test --show-details=always $(CABAL_FLAGS) $(CABAL_TEST_FLAGS))
+       (cd web && cabal $(CABAL_FLAGS) test --show-details=always $(CABAL_TEST_FLAGS))
 %/install/test: CABAL_INSTALL_FLAGS+=--enable-tests
 %/install/test: %/install
        
@@ -72,17 +76,17 @@ web/test:
 ##  doc
 ###
 .PHONY: doc
-doc: doc/xhtml lib/doc cli/doc web/doc
-%/prof: CABAL_INSTALL_FLAGS+=-fprof --ghc-options -fforce-recomp --enable-library-profiling --enable-executable-profiling
+doc: doc/xhtml $(HCOMPTA_INTERFACES:=/doc)
+%/prof: CABAL_INSTALL_FLAGS+=-fprof --enable-library-profiling --enable-executable-profiling
 %/prof: $(CABAL_SANDBOX) %
        
 
 lib/doc:
-       (cd lib && cabal haddock --hyperlink-source $(CABAL_FLAGS) $(CABAL_HADDOCK_FLAGS))
+       (cd lib && cabal $(CABAL_FLAGS) haddock --hyperlink-source $(CABAL_HADDOCK_FLAGS))
 cli/doc:
-       (cd cli && cabal haddock --hyperlink-source $(CABAL_FLAGS) $(CABAL_HADDOCK_FLAGS))
+       (cd cli && cabal $(CABAL_FLAGS) haddock --hyperlink-source $(CABAL_HADDOCK_FLAGS))
 web/doc:
-       (cd web && cabal haddock --hyperlink-source $(CABAL_FLAGS) $(CABAL_HADDOCK_FLAGS))
+       (cd web && cabal $(CABAL_FLAGS) haddock --hyperlink-source $(CABAL_HADDOCK_FLAGS))
 doc/%: .
        $(MAKE) -C doc $*
 
@@ -93,20 +97,48 @@ doc/%: .
 %/dev: %
        
 
+#
+##  dump
+###
+%/dump: CABAL_INSTALL_FLAGS+=-fdump
+%/dump: %
+       
+
+#
+##  hlint
+###
+hlint: $(HCOMPTA_INTERFACES:=/hlint.html)
+%/hlint: %/hlint.html
+       
+%/hlint.html: .
+       if hlint \
+        -i 'Redundant $$' \
+        -i 'Redundant bracket' \
+        -i 'Redundant do' \
+        -i 'Redundant lambda' \
+        -i "Use camelCase" \
+        -i 'Use if' \
+        -i 'Use String' \
+        -i 'Use string literal' \
+        --quiet --report="$@" \
+        "$*"/Hcompta; \
+       then rm -f "$@"; \
+       else echo; echo "BROWSE REPORT AT: file://$(abspath $@)"; fi
+
 #
 ##  prof
 ###
 .PHONY: prof
-prof: $(foreach command,$(HCOMPTA_COMMANDS),prof/$(command))
+prof: $(addprefix prof/,$(HCOMPTA_COMMANDS))
 
 prof/commit/$(commit):
        mkdir -p "$@"
 
-lib/install/prof: CABAL_INSTALL_FLAGS+=-fprof --ghc-options -fforce-recomp --enable-library-profiling
+lib/install/prof: CABAL_INSTALL_FLAGS+=-fprof --enable-library-profiling
 lib/install/prof: cli/unregister/sandbox lib/install | $(CABAL_SANDBOX)
        
 
-cli/install/prof: CABAL_INSTALL_FLAGS+=-fprof --ghc-options -fforce-recomp --enable-library-profiling --enable-executable-profiling
+cli/install/prof: CABAL_INSTALL_FLAGS+=-fprof --enable-library-profiling --enable-executable-profiling
 cli/install/prof: cli/install | $(CABAL_SANDBOX)
        mv \
         $(CABAL_SANDBOX)/bin/hcompta-cli \
@@ -153,8 +185,8 @@ prof/%.ledger.$(command): \
        $$(HCOMPTA_CLI_PROF) $$(HCOMPTA_FLAGS) \
         $(command) $$(HCOMPTA_COMMAND_FLAGS) $$(filter %.ledger,$$^) \
         >prof/$$*.ledger.$(command)
-       mv hcompta-cli-prof.hp   prof/commit/$(commit)/$$*.ledger.$(command).$(hC).hp
-       mv hcompta-cli-prof.prof prof/commit/$(commit)/$$*.ledger.$(command).$(hC).prof
+       mv $(notdir $(HCOMPTA_CLI_PROF)).hp   prof/commit/$(commit)/$$*.ledger.$(command).$(hC).hp
+       mv $(notdir $(HCOMPTA_CLI_PROF)).prof prof/commit/$(commit)/$$*.ledger.$(command).$(hC).prof
 
 prof/$(command)/$(hC): \
  $(addsuffix /$(command)/$(hC),$(wildcard prof/*.ledger))
@@ -179,8 +211,7 @@ endef
 
 prof/%.ledger/clean: \
  $(foreach command,$(HCOMPTA_COMMANDS), \
- prof/%.ledger/$(command)/clean \
- )
+ prof/%.ledger/$(command)/clean )
        
 
 $(foreach command,$(HCOMPTA_COMMANDS), \
@@ -195,19 +226,6 @@ $(foreach command,$(HCOMPTA_COMMANDS), \
 %.ps: %.hp
        (cd $(@D) && hp2ps -b -c -e$(GHC_PROF_PS_WIDTH) -g $(notdir $*.hp))
 
-#prof/%.ledger/clean:
-#      $(call rmw, \
-#       $(foreach command,$(HCOMPTA_COMMANDS), \
-#               prof/$*.ledger.$(command) \
-#               $(foreach hC,$(GHC_PROF_CATEGORIES),\
-#                       prof/commit/$(commit)/$*.ledger.$(command).$(hC).aux \
-#                       prof/commit/$(commit)/$*.ledger.$(command).$(hC).hp \
-#                       prof/commit/$(commit)/$*.ledger.$(command).$(hC).prof \
-#                       prof/commit/$(commit)/$*.ledger.$(command).$(hC).ps \
-#                       prof/commit/$(commit)/$*.ledger.$(command).$(hC).stats \
-#                        )))
-#      $(call rmdirw,prof/commit/$(commit))
-
 #
 ##  not-threaded
 ###
@@ -215,23 +233,35 @@ $(foreach command,$(HCOMPTA_COMMANDS), \
 %/not-threaded: %
        
 
+#
+##  ghc-pkg
+###
+unregister: $(HCOMPTA_INTERFACES:=/unregister)
+
+%/unregister: .
+       if    $(GHC_PKG) list       hcompta-$* | grep -q '^ * hcompta-$*-' ; \
+        then $(GHC_PKG) unregister hcompta-$* ; \
+        fi
+
+%/unregister/sandbox: GHC_PKG:=cabal sandbox hc-pkg
+%/unregister/sandbox: .
+       if    $(GHC_PKG) list       hcompta-$* | grep -q '^ * hcompta-$*-' ; \
+        then $(GHC_PKG) unregister hcompta-$* ; \
+        fi
+
 #
 ##  sandbox
 ###
 $(CABAL_SANDBOX):
-       cabal sandbox --sandbox="$@" init $(CABAL_FLAGS) $(CABAL_SANDBOX_FLAGS)
+       cabal $(CABAL_FLAGS) sandbox --sandbox="$@" $(CABAL_SANDBOX_FLAGS) init
 
 %/sandbox: GHC_PKG:=cabal sandbox hc-pkg
 %/sandbox: %
        
 
 #
-##  ghc-pkg
+##  stats
 ###
-
-unregister: $(addsuffix /unregister,web cli lib)
-
-%/unregister:
-       if    $(GHC_PKG) list       hcompta-$* | grep -q '^ * hcompta-$*-' ; \
-        then $(GHC_PKG) unregister hcompta-$* ; \
-        fi
+.PHONY: stats
+stats:
+       gitstats . $@