Changelog for dyre-0.9.2
0.9.2
- 
Support Cabal store in $XDG_STATE_HOME/cabal/store, which is the default location since cabal-install v3.10.
- 
Fix Cabal store package-db detection when package name contains hyphen characters. 
- 
Recognise NIX_GHCenvironment variable for better support of Nix environments.HC, if set, takes precedence.
0.9.1
- Tell GHC about the Cabal store package DB via the -package-dboption. This fixes compilation with Cabal store-based executables.
0.9.0
- 
realMaincan now return arbitrary types. To support this change,Paramsgot a new type variable.-- before data Params cfgType wrapMain :: Params cfgType -> cfgType -> IO () -- after data Params cfgType a wrapMain :: Params cfgType a -> cfgType -> IO a
- 
defaultParams, which containsundefinedfields, has been deprecated in favour of the new functionnewParams:-- here be bottoms defaultParams :: Params cfg a -- celestial music playing newParams :: String -- ^ 'projectName' -> (cfg -> IO a) -- ^ 'realMain' function -> (cfg -> String -> cfg) -- ^ 'showError' function -> Params cfg anewParamstakes values for the three required fields, so program authors can clearly see what they have to do and are less likely to make a mistake.
- 
Cabal store support: Users can add extra include dirs via the includeDirsfield ofParams. The program author just has to put the package's library directory in the newincludeDirsfield:import Config.Dyre import Paths_myapp (getLibDir) realMain = … showError = … myapp cfg = do libdir <- getLibDir let params = (newParams "myapp" realMain showError) { includeDirs = [libdir] } wrapMain params cfgIf an include dir appears to be in a Cabal store and matches the projectName, Dyre adds the corresponding-package-idoption. As a result, recompilation works for programs installed viacabal install.
- 
Stack support: if Dyre detects a stack.yamlalongside the custom configuration, it will use Stack to compile the program. Credit to Jaro Reinders for this feature.
- 
Dyre compiles the custom executable with -threadedwhen the main executable uses the threaded RTS. This means one less thing for program authors to remember (or forget) to do.
- 
Dyre now requires GHC >= 7.10. 
- 
Improved documentation. 
- 
The test suite was expanded, and can now be executed via cabal test.
- 
Dyre cleans up better after compilation (successful or unsuccesful), and behaves better when the custom configuration is removed. 
- 
Some versions of GHC write to standard error, even during a successful compilation. Dyre no longer treats this as a compilation failure, instead relying solely on GHC's exit status. 
- 
Dyre recognises the HCenvironment variable. If set, it will compile the program using the specified compiler.
- 
Fixes for Windows, including working with recent versions of the process package.