| Safe Haskell | None | 
|---|
RtClosureInspect
- cvObtainTerm :: HscEnv -> Int -> Bool -> RttiType -> HValue -> IO Term
- cvReconstructType :: HscEnv -> Int -> GhciType -> HValue -> IO (Maybe Type)
- improveRTTIType :: HscEnv -> RttiType -> RttiType -> Maybe TvSubst
- data  Term - = Term { }
- | Prim { }
- | Suspension { }
- | NewtypeWrap { }
- | RefWrap { - ty :: RttiType
- wrapped_term :: Term
 
 
- isTerm :: Term -> Bool
- isSuspension :: Term -> Bool
- isPrim :: Term -> Bool
- isFun :: Term -> Bool
- isFunLike :: Term -> Bool
- isNewtypeWrap :: Term -> Bool
- isFullyEvaluated :: a -> IO Bool
- isFullyEvaluatedTerm :: Term -> Bool
- termType :: Term -> RttiType
- mapTermType :: (RttiType -> Type) -> Term -> Term
- termTyVars :: Term -> TyVarSet
- foldTerm :: TermFold a -> Term -> a
- data  TermFold a = TermFold {- fTerm :: TermProcessor a a
- fPrim :: RttiType -> [Word] -> a
- fSuspension :: ClosureType -> RttiType -> HValue -> Maybe Name -> a
- fNewtypeWrap :: RttiType -> Either String DataCon -> a -> a
- fRefWrap :: RttiType -> a -> a
 
- foldTermM :: Monad m => TermFoldM m a -> Term -> m a
- data  TermFoldM m a = TermFoldM {- fTermM :: TermProcessor a (m a)
- fPrimM :: RttiType -> [Word] -> m a
- fSuspensionM :: ClosureType -> RttiType -> HValue -> Maybe Name -> m a
- fNewtypeWrapM :: RttiType -> Either String DataCon -> a -> m a
- fRefWrapM :: RttiType -> a -> m a
 
- idTermFold :: TermFold Term
- pprTerm :: TermPrinter -> TermPrinter
- cPprTerm :: Monad m => CustomTermPrinter m -> Term -> m SDoc
- cPprTermBase :: forall m. Monad m => CustomTermPrinter m
- type CustomTermPrinter m = TermPrinterM m -> [Precedence -> Term -> m (Maybe SDoc)]
- data Closure = Closure {}
- getClosureData :: a -> IO Closure
- data ClosureType
- isConstr :: ClosureType -> Bool
- isIndirection :: ClosureType -> Bool
Documentation
improveRTTIType :: HscEnv -> RttiType -> RttiType -> Maybe TvSubst
data Term
Constructors
| Term | |
| Prim | |
| Suspension | |
| NewtypeWrap | |
| RefWrap | |
| Fields 
 | |
Instances
isSuspension :: Term -> Bool
isNewtypeWrap :: Term -> Bool
isFullyEvaluated :: a -> IO Bool
isFullyEvaluatedTerm :: Term -> Bool
mapTermType :: (RttiType -> Type) -> Term -> Term
termTyVars :: Term -> TyVarSet
data TermFold a
Constructors
| TermFold | |
| Fields 
 | |
data TermFoldM m a
Constructors
| TermFoldM | |
| Fields 
 | |
pprTerm :: TermPrinter -> TermPrinter
cPprTerm :: Monad m => CustomTermPrinter m -> Term -> m SDoc
Takes a list of custom printers with a explicit recursion knot and a term, and returns the output of the first succesful printer, or the default printer
cPprTermBase :: forall m. Monad m => CustomTermPrinter m
type CustomTermPrinter m = TermPrinterM m -> [Precedence -> Term -> m (Maybe SDoc)]
data Closure
getClosureData :: a -> IO Closure
data ClosureType
Constructors
| Constr | |
| Fun | |
| Thunk Int | |
| ThunkSelector | |
| Blackhole | |
| AP | |
| PAP | |
| Indirection Int | |
| MutVar Int | |
| MVar Int | |
| Other Int | 
Instances
isConstr :: ClosureType -> Bool
isIndirection :: ClosureType -> Bool