{-# LANGUAGE CPP #-}
module Hhp.Gap (
#if __GLASGOW_HASKELL__ >= 902
module GHC.Types.TyThing.Ppr
#else
module GHC.Core.Ppr.TyThing
#endif
, implicitTyThings
, pagemode
, getUnitState
, languagesAndExtensions
, setEmptyLogger
, setLinkerOptions
, setLogger
, LogAction
, SourceError
, srcErrorMessages
, pprLocErrMessage
, ErrorMessages
, locA
, LOC
, guessTarget
, pprSigmaType
, getMessages
, hsPatType
, fromNE
, NamePprCtx
, getNamePprCtx
, mkScaledFunctionTys
) where
import GHC (Ghc, DynFlags(..), GhcLink(..))
import qualified GHC as G
import GHC.Utils.Ppr(Mode(..))
import GHC.Unit.State (UnitState)
import GHC.Driver.Session (supportedLanguagesAndExtensions)
import GHC.Utils.Outputable (SDoc)
#if __GLASGOW_HASKELL__ >= 906
import GHC (pushLogHookM, NamePprCtx, getNamePprCtx)
import GHC.Core.Type (mkScaledFunctionTys)
import GHC.Driver.Backend (interpreterBackend)
import GHC.Driver.Env (hsc_units)
import GHC.Driver.Errors.Types (ErrorMessages, GhcMessage)
import GHC.Hs.Syn.Type (hsPatType)
import GHC.Parser.Annotation (locA, LocatedA)
import GHC.Platform.Host (hostPlatformArchOS)
import GHC.Tc.Utils.TcType (pprSigmaType)
import GHC.Types.Error (getMessages)
import GHC.Types.SourceError (SourceError, srcErrorMessages)
import GHC.Types.TyThing (implicitTyThings)
import GHC.Types.TyThing.Ppr
import GHC.Utils.Error (pprLocMsgEnvelopeDefault, MsgEnvelope)
import GHC.Utils.Logger (LogAction)
import Data.List.NonEmpty (toList, NonEmpty)
pagemode :: Mode
pagemode :: Mode
pagemode = Bool -> Mode
PageMode Bool
True
getUnitState :: Ghc UnitState
getUnitState :: Ghc UnitState
getUnitState = (() :: Constraint) => HscEnv -> UnitState
HscEnv -> UnitState
hsc_units (HscEnv -> UnitState) -> Ghc HscEnv -> Ghc UnitState
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Ghc HscEnv
forall (m :: * -> *). GhcMonad m => m HscEnv
G.getSession
languagesAndExtensions :: [String]
languagesAndExtensions :: [String]
languagesAndExtensions = ArchOS -> [String]
supportedLanguagesAndExtensions ArchOS
hostPlatformArchOS
setEmptyLogger :: DynFlags -> DynFlags
setEmptyLogger :: DynFlags -> DynFlags
setEmptyLogger = DynFlags -> DynFlags
forall a. a -> a
id
setLinkerOptions :: DynFlags -> DynFlags
setLinkerOptions :: DynFlags -> DynFlags
setLinkerOptions DynFlags
df = DynFlags
df {
ghcLink = LinkInMemory
, backend = interpreterBackend
}
setLogger :: LogAction -> Ghc ()
setLogger :: LogAction -> Ghc ()
setLogger LogAction
logaction = (LogAction -> LogAction) -> Ghc ()
forall (m :: * -> *).
GhcMonad m =>
(LogAction -> LogAction) -> m ()
pushLogHookM (\LogAction
__defaultLogAction -> LogAction
logaction)
pprLocErrMessage :: MsgEnvelope GhcMessage -> SDoc
pprLocErrMessage :: MsgEnvelope GhcMessage -> SDoc
pprLocErrMessage = MsgEnvelope GhcMessage -> SDoc
forall e. Diagnostic e => MsgEnvelope e -> SDoc
pprLocMsgEnvelopeDefault
type LOC = LocatedA
guessTarget :: G.GhcMonad m => String -> m G.Target
guessTarget :: forall (m :: * -> *). GhcMonad m => String -> m Target
guessTarget String
file = String -> Maybe UnitId -> Maybe Phase -> m Target
forall (m :: * -> *).
GhcMonad m =>
String -> Maybe UnitId -> Maybe Phase -> m Target
G.guessTarget String
file Maybe UnitId
forall a. Maybe a
Nothing Maybe Phase
forall a. Maybe a
Nothing
fromNE :: NonEmpty a -> [a]
fromNE :: forall a. NonEmpty a -> [a]
fromNE = NonEmpty a -> [a]
forall a. NonEmpty a -> [a]
toList
#elif __GLASGOW_HASKELL__ >= 904
import GHC (Backend(..), Type, pushLogHookM)
import GHC.Core.TyCo.Rep (Scaled)
import GHC.Driver.Env (hsc_units)
import GHC.Driver.Errors.Types (ErrorMessages, GhcMessage)
import GHC.Hs.Syn.Type (hsPatType)
import GHC.Parser.Annotation (locA, LocatedA)
import GHC.Platform.Host (hostPlatformArchOS)
import GHC.Tc.Utils.TcType (pprSigmaType, mkVisFunTys)
import GHC.Types.Error (getMessages)
import GHC.Types.SourceError (SourceError, srcErrorMessages)
import GHC.Types.TyThing (implicitTyThings)
import GHC.Types.TyThing.Ppr
import GHC.Utils.Error (pprLocMsgEnvelope, MsgEnvelope)
import GHC.Utils.Logger (LogAction)
pagemode :: Mode
pagemode = PageMode True
getUnitState :: Ghc UnitState
getUnitState = hsc_units <$> G.getSession
languagesAndExtensions :: [String]
languagesAndExtensions = supportedLanguagesAndExtensions hostPlatformArchOS
setEmptyLogger :: DynFlags -> DynFlags
setEmptyLogger = id
setLinkerOptions :: DynFlags -> DynFlags
setLinkerOptions df = df {
ghcLink = LinkInMemory
, backend = Interpreter
}
setLogger :: LogAction -> Ghc ()
setLogger logaction = pushLogHookM (\__defaultLogAction -> logaction)
pprLocErrMessage :: MsgEnvelope GhcMessage -> SDoc
pprLocErrMessage = pprLocMsgEnvelope
type LOC = LocatedA
guessTarget :: G.GhcMonad m => String -> m G.Target
guessTarget file = G.guessTarget file Nothing Nothing
fromNE :: a -> a
fromNE = id
type NamePprCtx = G.PrintUnqualified
getNamePprCtx :: G.GhcMonad m => m G.PrintUnqualified
getNamePprCtx = G.getPrintUnqual
mkScaledFunctionTys :: [Scaled Type] -> Type -> Type
mkScaledFunctionTys = mkVisFunTys
#elif __GLASGOW_HASKELL__ >= 902
import GHC (Backend(..), pushLogHookM, Type)
import GHC.Core.TyCo.Rep (Scaled)
import GHC.Driver.Env (hsc_units)
import GHC.Parser.Annotation (locA, LocatedA)
import GHC.Platform.Host (hostPlatformArchOS)
import GHC.Tc.Utils.TcType (mkVisFunTys)
import GHC.Tc.Utils.Zonk (hsPatType)
import GHC.Types.SourceError (SourceError, srcErrorMessages)
import GHC.Types.TyThing (implicitTyThings)
import GHC.Types.TyThing.Ppr
import GHC.Utils.Error (ErrorMessages, DecoratedSDoc, pprLocMsgEnvelope, MsgEnvelope)
import GHC.Utils.Logger (LogAction)
pagemode :: Mode
pagemode = PageMode True
getUnitState :: Ghc UnitState
getUnitState = hsc_units <$> G.getSession
languagesAndExtensions :: [String]
languagesAndExtensions = supportedLanguagesAndExtensions hostPlatformArchOS
setEmptyLogger :: DynFlags -> DynFlags
setEmptyLogger = id
setLinkerOptions :: DynFlags -> DynFlags
setLinkerOptions df = df {
ghcLink = LinkInMemory
, backend = Interpreter
}
setLogger :: LogAction -> Ghc ()
setLogger logaction = pushLogHookM (\__defaultLogAction -> logaction)
pprLocErrMessage :: MsgEnvelope DecoratedSDoc -> SDoc
pprLocErrMessage = pprLocMsgEnvelope
type LOC = LocatedA
guessTarget :: G.GhcMonad m => String -> m G.Target
guessTarget file = G.guessTarget file Nothing
pprSigmaType :: G.Type -> SDoc
pprSigmaType = pprTypeForUser
getMessages :: a -> a
getMessages = id
fromNE :: a -> a
fromNE = id
type NamePprCtx = G.PrintUnqualified
getNamePprCtx :: G.GhcMonad m => m G.PrintUnqualified
getNamePprCtx = G.getPrintUnqual
mkScaledFunctionTys :: [Scaled Type] -> Type -> Type
mkScaledFunctionTys = mkVisFunTys
#else
import GHC (HscTarget(..), getSessionDynFlags, setSessionDynFlags, Located, Type)
import GHC.Core.Ppr.TyThing
import GHC.Core.TyCo.Rep (Scaled)
import GHC.Data.Bag (Bag)
import GHC.Driver.Session (LogAction)
import GHC.Driver.Types (SourceError, srcErrorMessages, implicitTyThings)
import GHC.Platform.Host (cHostPlatformMini)
import GHC.Tc.Utils.TcType (mkVisFunTys)
import GHC.Tc.Utils.Zonk (hsPatType)
import GHC.Utils.Error (ErrMsg, pprLocErrMsg)
import Control.Monad (void)
pagemode :: Mode
pagemode = PageMode
getUnitState :: Ghc UnitState
getUnitState = G.unitState <$> G.getSessionDynFlags
languagesAndExtensions :: [String]
languagesAndExtensions = supportedLanguagesAndExtensions cHostPlatformMini
setEmptyLogger :: DynFlags -> DynFlags
setEmptyLogger df = df { G.log_action = \_ _ _ _ _ -> return () }
setLinkerOptions :: DynFlags -> DynFlags
setLinkerOptions df = df {
ghcLink = LinkInMemory
, hscTarget = HscInterpreted
}
setLogger :: LogAction -> Ghc ()
setLogger logaction = do
dflag <- getSessionDynFlags
void $ setSessionDynFlags dflag { log_action = logaction }
pprLocErrMessage :: ErrMsg -> SDoc
pprLocErrMessage = pprLocErrMsg
type ErrorMessages = Bag ErrMsg
locA :: a -> a
locA = id
type LOC = Located
guessTarget :: G.GhcMonad m => String -> m G.Target
guessTarget file = G.guessTarget file Nothing
pprSigmaType :: G.Type -> SDoc
pprSigmaType = pprTypeForUser
getMessages :: a -> a
getMessages = id
fromNE :: a -> a
fromNE = id
type NamePprCtx = G.PrintUnqualified
getNamePprCtx :: G.GhcMonad m => m G.PrintUnqualified
getNamePprCtx = G.getPrintUnqual
mkScaledFunctionTys :: [Scaled Type] -> Type -> Type
mkScaledFunctionTys = mkVisFunTys
#endif