Safe Haskell | None |
---|
- module IfaceType
- data IfaceDecl
- = IfaceId { }
- | IfaceData {
- ifName :: OccName
- ifCType :: Maybe CType
- ifTyVars :: [IfaceTvBndr]
- ifCtxt :: IfaceContext
- ifCons :: IfaceConDecls
- ifRec :: RecFlag
- ifGadtSyntax :: Bool
- ifAxiom :: Maybe IfExtName
- | IfaceSyn { }
- | IfaceClass {
- ifCtxt :: IfaceContext
- ifName :: OccName
- ifTyVars :: [IfaceTvBndr]
- ifFDs :: [FunDep FastString]
- ifATs :: [IfaceAT]
- ifSigs :: [IfaceClassOp]
- ifRec :: RecFlag
- | IfaceAxiom { }
- | IfaceForeign { }
- data IfaceClassOp = IfaceClassOp OccName DefMethSpec IfaceType
- data IfaceAT = IfaceAT IfaceDecl [IfaceATDefault]
- data IfaceATDefault = IfaceATD [IfaceTvBndr] [IfaceType] IfaceType
- data IfaceConDecl = IfCon {
- ifConOcc :: OccName
- ifConWrapper :: Bool
- ifConInfix :: Bool
- ifConUnivTvs :: [IfaceTvBndr]
- ifConExTvs :: [IfaceTvBndr]
- ifConEqSpec :: [(OccName, IfaceType)]
- ifConCtxt :: IfaceContext
- ifConArgTys :: [IfaceType]
- ifConFields :: [OccName]
- ifConStricts :: [HsBang]
- data IfaceConDecls
- data IfaceExpr
- = IfaceLcl IfLclName
- | IfaceExt IfExtName
- | IfaceType IfaceType
- | IfaceCo IfaceType
- | IfaceTuple TupleSort [IfaceExpr]
- | IfaceLam IfaceBndr IfaceExpr
- | IfaceApp IfaceExpr IfaceExpr
- | IfaceCase IfaceExpr IfLclName [IfaceAlt]
- | IfaceECase IfaceExpr IfaceType
- | IfaceLet IfaceBinding IfaceExpr
- | IfaceCast IfaceExpr IfaceCoercion
- | IfaceLit Literal
- | IfaceFCall ForeignCall IfaceType
- | IfaceTick IfaceTickish IfaceExpr
- type IfaceAlt = (IfaceConAlt, [IfLclName], IfaceExpr)
- data IfaceLetBndr = IfLetBndr IfLclName IfaceType IfaceIdInfo
- data IfaceBinding
- data IfaceConAlt
- data IfaceIdInfo
- = NoInfo
- | HasInfo [IfaceInfoItem]
- data IfaceIdDetails
- data IfaceUnfolding
- data IfaceInfoItem
- data IfaceRule = IfaceRule {}
- data IfaceAnnotation = IfaceAnnotation {}
- type IfaceAnnTarget = AnnTarget OccName
- data IfaceClsInst = IfaceClsInst {}
- data IfaceFamInst = IfaceFamInst {}
- data IfaceTickish
- ifaceDeclImplicitBndrs :: IfaceDecl -> [OccName]
- visibleIfConDecls :: IfaceConDecls -> [IfaceConDecl]
- freeNamesIfDecl :: IfaceDecl -> NameSet
- freeNamesIfRule :: IfaceRule -> NameSet
- freeNamesIfFamInst :: IfaceFamInst -> NameSet
- pprIfaceExpr :: (SDoc -> SDoc) -> IfaceExpr -> SDoc
- pprIfaceDeclHead :: IfaceContext -> OccName -> [IfaceTvBndr] -> SDoc
Documentation
module IfaceType
IfaceId | |
| |
IfaceData | |
| |
IfaceSyn | |
IfaceClass | |
| |
IfaceAxiom | |
IfaceForeign | |
|
data IfaceClassOp Source
data IfaceATDefault Source
data IfaceConDecl Source
IfCon | |
|
data IfaceConDecls Source
type IfaceAlt = (IfaceConAlt, [IfLclName], IfaceExpr)Source
data IfaceBinding Source
data IfaceConAlt Source
data IfaceIdDetails Source
data IfaceUnfolding Source
data IfaceInfoItem Source
IfaceRule | |
|
data IfaceAnnotation Source
type IfaceAnnTarget = AnnTarget OccNameSource
data IfaceClsInst Source
IfaceClsInst | |
|
freeNamesIfDecl :: IfaceDecl -> NameSetSource
Finding the Names in IfaceSyn
pprIfaceExpr :: (SDoc -> SDoc) -> IfaceExpr -> SDocSource
Pretty Print an IfaceExpre
The first argument should be a function that adds parens in context that need an atomic value (e.g. function args)
pprIfaceDeclHead :: IfaceContext -> OccName -> [IfaceTvBndr] -> SDocSource