stack: bump to lts-13.19
[haskell/symantic.git] / GNUmakefile
index ead4bfdaecee9424a38e8b193b4d952bc3da78dc..b7fa879f58b3be6e15b5ff83e51dcf9d5732ab7c 100644 (file)
@@ -1,11 +1,15 @@
-PKGS := symantic-grammar symantic-document symantic symantic-lib
-HS := $(shell find $(PKGS) -name '*.hs' -not -name 'HLint.hs')
+PKGS := \
+ symantic-grammar \
+ symantic-document \
+ symantic \
+ symantic-lib
+HS = $(shell find $(PKGS) -name '*.hs' -not -name 'HLint.hs')
 
 all: build
 
 build: $(PKGS:=/build)
 %/build:
-       cd $*; stack $(STACK_FLAGS) build $(STACK_BUILD_FLAGS)
+       cd $* && stack $(STACK_FLAGS) build $(STACK_BUILD_FLAGS)
 .PHONY: $(PKGS) $(foreach p,$(PKGS),$(eval $p: $p/build))
 
 .PHONY: $(PKGS:=/test)
@@ -13,26 +17,41 @@ test: $(PKGS:=/test)
 define test
 $p/test:
        ! grep -q '^Test-Suite\>' $p/$p.cabal || \
-       { cd $p; stack $$(STACK_FLAGS) test $$(STACK_TEST_FLAGS); }
+       { cd $p && stack $$(STACK_FLAGS) test $$(STACK_TEST_FLAGS); }
 endef
 $(foreach p,$(PKGS),$(eval $(call test)))
 
+GHCID_TEST_ARGS ?=
+GHCID_TEST ?= ":main $(GHCID_TEST_ARGS)"
+ghcid: $(PKGS:=/ghcid)
+%/ghcid:
+       cd $* && ghcid \
+        --warnings \
+        --command "stack $(STACK_FLAGS) $(GHCID_STACK_FLAGS) ghci $(GHCID_GHCI_FLAGS) \
+          $$(2>&1 stack ide targets | grep -v :test:) \
+          --ghci-options=-fobject-code" \
+        --test $(GHCID_TEST) \
+        $(GHCID_FLAGS)
+
 clean:   $(PKGS:=/clean)
 cleaner: $(PKGS:=/cleaner)
 %/clean:
-       cd $*; stack $(STACK_FLAGS) clean $(STACK_CLEAN_FLAGS)
+       cd $* && stack $(STACK_FLAGS) clean $(STACK_CLEAN_FLAGS)
 %/cleaner:
-       cd $*; stack $(STACK_FLAGS) clean --full $(STACK_CLEAN_FLAGS)
+       cd $* && stack $(STACK_FLAGS) clean --full $(STACK_CLEAN_FLAGS)
 
 %/fast: override STACK_BUILD_FLAGS+=--fast
 %/fast: override STACK_HADDOCK_FLAGS+=--fast
 %/fast: override STACK_TEST_FLAGS+=--fast
 %/fast: %
        
+%/accept: override STACK_TEST_ARGS+=--accept
+%/accept: %
+       
 
 doc: $(PKGS:=/doc)
 %/doc:
-       cd $*; stack $(STACK_FLAGS) haddock $(STACK_HADDOCK_FLAGS)
+       cd $* && stack $(STACK_FLAGS) haddock $(STACK_HADDOCK_FLAGS)
 %.html: %.md
        markdown $*.md >$*.html
 %.html/view: %.html
@@ -46,7 +65,7 @@ HLint.hs: $(HS)
 
 lint: $(PKGS:=/lint) $(HS)
 %/lint: HLint.hs
-       cd $*; if hlint --quiet --report=hlint.html -XNoCPP \
+       cd $* && if hlint --quiet --report=hlint.html -XNoCPP \
         $(shell cabal-cargs --format=ghc --only=default_extensions --sourcefile=$*) $(HLINT_FLAGS) .; \
        then rm -f hlint.html; \
        else sensible-browser ./hlint.html & fi
@@ -61,10 +80,10 @@ tag: $(PKGS:=/tag)
 
 tar: $(PKGS:=/tar)
 %/tar:
-       cd $*; stack $(STACK_FLAGS) sdist $(STACK_SDIST_FLAGS)
+       cd $* && stack $(STACK_FLAGS) sdist $(STACK_SDIST_FLAGS)
 upload: $(PKGS:=/upload)
 %/upload:
-       cd $*; LANG=C stack $(STACK_FLAGS) upload $(STACK_UPLOAD_FLAGS) .
+       cd $* && LANG=C stack $(STACK_FLAGS) upload $(STACK_UPLOAD_FLAGS) .
 
 .PHONY: stats
 stats: