stack: bump to lts-12.25
[majurity.git] / GNUmakefile
index 01c8d507d7ddcf6ff72bd7113469c4f4d0372287..7b3e132b1acf7b36eee1a77b26db45806a77be96 100644 (file)
@@ -1,5 +1,8 @@
-CABAL := $(shell find . -name '*.cabal' -print -quit)
-HS := $(shell find . -name '*.hs')
+cabal := $(shell find . -name '*.cabal' -print -quit)
+package := $(notdir ./$(cabal:.cabal=))
+QUICKCHECK_TESTS = 1000
+QUICKCHECK_MAXSIZE = 100
+TEST_FLAGS = --quickcheck-tests $(QUICKCHECK_TESTS) --quickcheck-max-size $(QUICKCHECK_MAXSIZE)
 
 all: build
 
@@ -8,8 +11,23 @@ build:
 
 .PHONY: test
 test:
-       ! grep -q '^Test-Suite\>' $(CABAL) || \
-       { stack $(STACK_FLAGS) test $(STACK_TEST_FLAGS); }
+       ! grep -q '^Test-Suite\>' $(cabal) || \
+       { stack $(STACK_FLAGS) test --test-arguments "$(TEST_FLAGS)" $(STACK_TEST_FLAGS); }
+
+%/quickcheck: override QUICKCHECK_TESTS=10000
+%/quickcheck: override QUICKCHECK_MAXSIZE=1000
+%/quickcheck: %
+       
+
+GHCID_TEST ?= System.Environment.withArgs (Data.List.words "--color always") main `Control.Exception.finally` System.IO.putStrLn "\x1b[m"
+ghcid:
+       ghcid \
+        --warnings \
+        --command "stack $(STACK_FLAGS) ghci --test \
+          $(package):lib \
+          $(package):$(package)-test \
+          --ghci-options=-fobject-code" \
+        --test '$(GHCID_TEST)'
 
 clean:
        stack $(STACK_FLAGS) clean $(STACK_CLEAN_FLAGS)
@@ -19,6 +37,8 @@ cleaner:
 %/fast: override STACK_BUILD_FLAGS+=--fast
 %/fast: override STACK_HADDOCK_FLAGS+=--fast
 %/fast: override STACK_TEST_FLAGS+=--fast
+%/fast: override QUICKCHECK_TESTS=100
+%/fast: override QUICKCHECK_MAXSIZE=100
 %/fast: %
        
 
@@ -29,28 +49,28 @@ doc:
 %.html/view: %.html
        sensible-browser $*.html
 
-HLint.hs: $(HS)
+HLint.hs: $(shell find . -name '*.hs' -not -name 'HLint.hs')
        sed -i -e '/^-- BEGIN: generated hints/,/^-- END: Generated by hlint/d' HLint.hs
        echo '-- BEGIN: generated hints' >> HLint.hs
        hlint --find . | grep '^'infix | sort -u >> HLint.hs
        echo '-- END: generated hints' >> HLint.hs
 
-lint: HLint.hs $(HS)
+lint: HLint.hs
        if hlint --quiet --report=hlint.html -XNoCPP \
-        $(shell cabal-cargs --format=ghc --only=default_extensions --sourcefile=$(CABAL)) $(HLINT_FLAGS) .; \
+        $(shell cabal-cargs --format=ghc --only=default_extensions --sourcefile=$(cabal)) $(HLINT_FLAGS) .; \
        then rm -f hlint.html; \
        else sensible-browser hlint.html & fi
 
 tag:
-       name=$$(sed -ne 's/^name: *\(.*\)/\1/p' "$(CABAL)"); \
-       version=$$(sed -ne 's/^version: *\(.*\)/\1/p' "$(CABAL)"); \
+       name=$$(sed -ne 's/^name: *\(.*\)/\1/p' $(cabal)); \
+       version=$$(sed -ne 's/^version: *\(.*\)/\1/p' $(cabal)); \
        git tag --merged | grep -Fqx "$$name-$$version" || \
        git tag -f -s -m "$$name v$$version" $$name-$$version
 
 tar:
-       LANG=C stack $(STACK_FLAGS) sdist --sign
+       stack $(STACK_FLAGS) sdist $(STACK_SDIST_FLAGS)
 upload:
-       LANG=C stack $(STACK_FLAGS) upload .
+       LANG=C stack $(STACK_FLAGS) upload $(STACK_UPLOAD_FLAGS) .
 
 .PHONY: stats
 stats: