-.PHONY : test publish_doc doc src_html hlint
-
-$(BIN): src/*.hs
- runghc Setup.hs clean
- runghc Setup.hs configure --user --flags=${FLAGS}
- runghc Setup.hs build
-
-$(DOCTESTS_BIN): src/*.hs test/Doctests.hs
- runghc Setup.hs configure --user --flags=${FLAGS} --enable-tests
- runghc Setup.hs build
-
-$(TESTSUITE_BIN): src/*.hs test/TestSuite.hs
- runghc Setup.hs configure --user --flags=${FLAGS} --enable-tests
- runghc Setup.hs build
-
-llvm: src/*.hs
- FLAGS="llvm" make
-
-profile: src/*.hs
- runghc Setup.hs configure --user --enable-executable-profiling
- runghc Setup.hs build
-
-hpc: src/*.hs
- FLAGS="hpc" make
+# Append these warnings to the HCFLAGS environment variable that gets
+# passed as options to GHC. We want to see the warnings while developing
+# but don't want them hard-coded in the cabal file for end users.
+HCFLAGS += -Weverything \
+ -Wno-implicit-prelude \
+ -Wno-safe \
+ -Wno-unsafe \
+ -Wno-all-missed-specialisations \
+ -Wno-prepositive-qualified-module \
+ -Wno-missing-safe-haskell-mode \
+ -Wno-missing-deriving-strategies \
+ -Wno-missing-kind-signatures \
+ -rtsopts \
+ -threaded
+
+.PHONY : test doc dist hlint
+
+$(BIN): $(PN).cabal $(SRCS)
+ runghc Setup.hs configure --user --prefix=/
+ runghc Setup.hs build --ghc-options="${HCFLAGS}"
+
+$(DOCTESTS_BIN): $(SRCS) test/Doctests.hs
+ runghc Setup.hs configure --user --prefix=/ --enable-tests
+ runghc Setup.hs build --ghc-options="${HCFLAGS}"
+
+$(TESTSUITE_BIN): $(SRCS) test/TestSuite.hs
+ runghc Setup.hs configure --user --prefix=/ --enable-tests
+ runghc Setup.hs build --ghc-options="${HCFLAGS}"