-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
.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)
%/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: %
%.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: