Browse files

Upstream update of cabal-package.mk

  • Loading branch information...
1 parent f11fa41 commit 6fe28328e08d1a278656e74f214448cd119171f0 @phonohawk committed Mar 4, 2012
Showing with 49 additions and 12 deletions.
  1. +49 −12 cabal-package.mk
View
61 cabal-package.mk
@@ -18,6 +18,12 @@ HPC ?= hpc
DITZ ?= ditz
CONFIGURE_ARGS ?= --disable-optimization
+HADDOCK_OPTS ?= --hyperlink-source
+HLINT_OPTS ?= \
+ --hint=Default --hint=Dollar --hint=Generalise \
+ --cross \
+ --ignore="Parse error" \
+ --report=dist/report.html
SETUP_FILE := $(wildcard Setup.*hs)
CABAL_FILE := $(wildcard *.cabal)
@@ -73,14 +79,18 @@ $(BUILDINFO_FILE): $(BUILDINFO_IN_FILE) configure
Setup: $(SETUP_FILE)
$(GHC) --make Setup
+reconfigure:
+ rm -f dist/setup-config
+ $(MAKE) setup-config
+
clean: clean-hook
$(RM_RF) dist Setup *.o *.hi .setup-config *.buildinfo *.tix .hpc
$(FIND) . -name '*~' -exec rm -f {} \;
clean-hook:
doc: setup-config
- ./Setup haddock
+ ./Setup haddock $(HADDOCK_OPTS)
install: build
$(SUDO) ./Setup install
@@ -96,35 +106,62 @@ test: build
$(HPC) markup --destdir="dist/hpc" --fun-entry-count "merged.tix"; \
fi
-ditz:
- $(DITZ) html dist/ditz
-
+# -- Find FIXME Tags ----------------------------------------------------------
fixme:
@$(FIND) . \
\( -name 'dist' -or -name '.git' -or -name '_darcs' \) -prune \
-or \
\( -name '*.c' -or -name '*.h' -or \
-name '*.hs' -or -name '*.lhs' -or \
-name '*.hsc' -or -name '*.cabal' \) \
- -exec egrep -i '(fixme|thinkme)' {} \+ \
- || echo 'No FIXME or THINKME found.'
+ -exec egrep 'FIXME|THINKME|TODO' {} \+ \
+ || echo 'No FIXME, THINKME, nor TODO found.'
+# -- HLint --------------------------------------------------------------------
+HLINT_TARGETS ?= $$(find -E . -type d -name dist -prune -o -regex '.*\.(hsc?|lhs)' -print)
lint:
- $(HLINT) . --report
+ $(HLINT) $(HLINT_TARGETS) $(HLINT_OPTS)
+
+# -- Ditz the Distributed Issue Tracker ---------------------------------------
+ifeq (,$(wildcard .ditz-config))
+ditz:
+else
+ditz:
+ $(DITZ) html dist/ditz
+
+ChangeLog:
+ rm -f $@
+ $(DITZ) releases | awk '{print $$1}' | sort --reverse | while read i; do \
+ $(DITZ) changelog $$i >> $@; \
+ done
+ head $@
+endif
+
+# -- Pushing to remote hosts --------------------------------------------------
+push: push-repo push-ditz push-doc
-push: doc ditz
+push-repo:
if [ -d "_darcs" ]; then \
darcs push; \
elif [ -d ".git" ]; then \
git push --all && git push --tags; \
fi
+
+push-ditz: ditz
+ if [ -d "dist/ditz" ]; then \
+ rsync -av --delete \
+ dist/ditz/ \
+ www@nem.cielonegro.org:static.cielonegro.org/htdocs/ditz/$(PKG_NAME); \
+ fi
+
+push-doc: doc
if [ -d "dist/doc" ]; then \
rsync -av --delete \
dist/doc/html/$(PKG_NAME)/ \
www@nem.cielonegro.org:static.cielonegro.org/htdocs/doc/$(PKG_NAME); \
fi
- rsync -av --delete \
- dist/ditz/ \
- www@nem.cielonegro.org:static.cielonegro.org/htdocs/ditz/$(PKG_NAME)
-.PHONY: build build-hook setup-config setup-config-hook run clean clean-hook install doc sdist test lint push
+# -- Phony Targets ------------------------------------------------------------
+.PHONY: build build-hook setup-config setup-config-hook run clean clean-hook \
+ install doc sdist test lint push push-repo push-ditz push-doc \
+ ChangeLog

0 comments on commit 6fe2832

Please sign in to comment.