Renames in symantic-document.
[haskell/symantic.git] / GNUmakefile
index 5cbc696ad9b08992496dee79352e8e1c3f2748ae..ead4bfdaecee9424a38e8b193b4d952bc3da78dc 100644 (file)
@@ -1,5 +1,5 @@
 PKGS := symantic-grammar symantic-document symantic symantic-lib
-HS := $(shell find $(PKGS) -name '*.hs')
+HS := $(shell find $(PKGS) -name '*.hs' -not -name 'HLint.hs')
 
 all: build
 
@@ -8,10 +8,14 @@ build: $(PKGS:=/build)
        cd $*; stack $(STACK_FLAGS) build $(STACK_BUILD_FLAGS)
 .PHONY: $(PKGS) $(foreach p,$(PKGS),$(eval $p: $p/build))
 
+.PHONY: $(PKGS:=/test)
 test: $(PKGS:=/test)
-%/test:
-       ! grep -q '^Test-Suite\>' $*/$*.cabal || \
-       { cd $*; stack $(STACK_FLAGS) test $(STACK_TEST_FLAGS); }
+define test
+$p/test:
+       ! grep -q '^Test-Suite\>' $p/$p.cabal || \
+       { cd $p; stack $$(STACK_FLAGS) test $$(STACK_TEST_FLAGS); }
+endef
+$(foreach p,$(PKGS),$(eval $(call test)))
 
 clean:   $(PKGS:=/clean)
 cleaner: $(PKGS:=/cleaner)
@@ -45,7 +49,7 @@ lint: $(PKGS:=/lint) $(HS)
        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
+       else sensible-browser ./hlint.html & fi
 
 tag: $(PKGS:=/tag)
 %/tag:
@@ -55,10 +59,12 @@ tag: $(PKGS:=/tag)
        git tag --merged | grep -Fqx "$$name-$$version" || \
        git tag -f -s -m "$$name v$$version" $$name-$$version
 
+tar: $(PKGS:=/tar)
+%/tar:
+       cd $*; stack $(STACK_FLAGS) sdist $(STACK_SDIST_FLAGS)
 upload: $(PKGS:=/upload)
 %/upload:
-       cd $*; LANG=C stack $(STACK_FLAGS) sdist --sign
-       cd $*; LANG=C stack $(STACK_FLAGS) upload .
+       cd $*; LANG=C stack $(STACK_FLAGS) upload $(STACK_UPLOAD_FLAGS) .
 
 .PHONY: stats
 stats: