module HIE.Bios.Ghc.Check (
checkSyntax
, check
, expandTemplate
, expand
) where
import DynFlags (dopt_set, DumpFlag(Opt_D_dump_splices))
import GHC (Ghc, DynFlags(..), GhcMonad)
import HIE.Bios.Ghc.Api
import HIE.Bios.Ghc.Logger
import HIE.Bios.Types
import HIE.Bios.Ghc.Load
import Outputable
checkSyntax :: Options
-> Cradle
-> [FilePath]
-> IO String
checkSyntax _ _ [] = return ""
checkSyntax opt cradle files = withGhcT $ do
pprTrace "cradle" (text $ show cradle) (return ())
initializeFlagsWithCradle (head files) cradle
either id id <$> check opt files
where
check :: (GhcMonad m)
=> Options
-> [FilePath]
-> m (Either String String)
check opt fileNames = withLogger opt setAllWarningFlags $ setTargetFiles (map dup fileNames)
dup :: a -> (a, a)
dup x = (x, x)
expandTemplate :: Options
-> Cradle
-> [FilePath]
-> IO String
expandTemplate _ _ [] = return ""
expandTemplate opt cradle files = withGHC sessionName $ do
initializeFlagsWithCradle (head files) cradle
either id id <$> expand opt files
where
sessionName = case files of
[file] -> file
_ -> "MultipleFiles"
expand :: Options
-> [FilePath]
-> Ghc (Either String String)
expand opt fileNames = withLogger opt (setDumpSplices . setNoWarningFlags) $ setTargetFiles (map dup fileNames)
setDumpSplices :: DynFlags -> DynFlags
setDumpSplices dflag = dopt_set dflag Opt_D_dump_splices