{-# LANGUAGE LambdaCase #-}
module Language.Haskell.Liquid.Cabal (liquidHaskellMain) where
import Distribution.Simple
import System.Environment
liquidHaskellMain :: IO ()
liquidHaskellMain :: IO ()
liquidHaskellMain = do
Maybe String
mbDevMode <- String -> IO (Maybe String)
lookupEnv String
"LIQUID_DEV_MODE"
UserHooks -> IO ()
defaultMainWithHooks (Maybe String -> UserHooks
devModeHooks Maybe String
mbDevMode)
devModeHooks :: Maybe String -> UserHooks
devModeHooks :: Maybe String -> UserHooks
devModeHooks = \case
Maybe String
Nothing -> UserHooks
simpleUserHooks
Just String
x | String
x String -> String -> Bool
forall a. Eq a => a -> a -> Bool
== String
"false" -> UserHooks
simpleUserHooks
Just String
_ -> UserHooks
simpleUserHooks { buildHook :: PackageDescription
-> LocalBuildInfo -> UserHooks -> BuildFlags -> IO ()
buildHook = \PackageDescription
_ LocalBuildInfo
_ UserHooks
_ BuildFlags
_ -> () -> IO ()
forall (m :: * -> *) a. Monad m => a -> m a
return () }