Safe Haskell | None |
---|---|
Language | Haskell2010 |
Module for coercion axioms, used to represent type family instances and newtypes
- data BranchFlag
- type Branched = Branched
- type Unbranched = Unbranched
- type BranchIndex = Int
- data Branches br
- manyBranches :: [CoAxBranch] -> Branches Branched
- unbranched :: CoAxBranch -> Branches Unbranched
- fromBranches :: Branches br -> [CoAxBranch]
- numBranches :: Branches br -> Int
- mapAccumBranches :: ([CoAxBranch] -> CoAxBranch -> CoAxBranch) -> Branches br -> Branches br
- data CoAxiom br = CoAxiom {
- co_ax_unique :: Unique
- co_ax_name :: Name
- co_ax_role :: Role
- co_ax_tc :: TyCon
- co_ax_branches :: Branches br
- co_ax_implicit :: Bool
- data CoAxBranch = CoAxBranch {}
- toBranchedAxiom :: CoAxiom br -> CoAxiom Branched
- toUnbranchedAxiom :: CoAxiom br -> CoAxiom Unbranched
- coAxiomName :: CoAxiom br -> Name
- coAxiomArity :: CoAxiom br -> BranchIndex -> Arity
- coAxiomBranches :: CoAxiom br -> Branches br
- coAxiomTyCon :: CoAxiom br -> TyCon
- isImplicitCoAxiom :: CoAxiom br -> Bool
- coAxiomNumPats :: CoAxiom br -> Int
- coAxiomNthBranch :: CoAxiom br -> BranchIndex -> CoAxBranch
- coAxiomSingleBranch_maybe :: CoAxiom br -> Maybe CoAxBranch
- coAxiomRole :: CoAxiom br -> Role
- coAxiomSingleBranch :: CoAxiom Unbranched -> CoAxBranch
- coAxBranchTyVars :: CoAxBranch -> [TyVar]
- coAxBranchCoVars :: CoAxBranch -> [CoVar]
- coAxBranchRoles :: CoAxBranch -> [Role]
- coAxBranchLHS :: CoAxBranch -> [Type]
- coAxBranchRHS :: CoAxBranch -> Type
- coAxBranchSpan :: CoAxBranch -> SrcSpan
- coAxBranchIncomps :: CoAxBranch -> [CoAxBranch]
- placeHolderIncomps :: [CoAxBranch]
- data Role
- fsFromRole :: Role -> FastString
- data CoAxiomRule = CoAxiomRule {
- coaxrName :: FastString
- coaxrAsmpRoles :: [Role]
- coaxrRole :: Role
- coaxrProves :: [Eqn] -> Maybe Eqn
- type Eqn = Pair Type
- data BuiltInSynFamily = BuiltInSynFamily {
- sfMatchFam :: [Type] -> Maybe (CoAxiomRule, [Type], Type)
- sfInteractTop :: [Type] -> Type -> [Eqn]
- sfInteractInert :: [Type] -> Type -> [Type] -> Type -> [Eqn]
- trivialBuiltInFamily :: BuiltInSynFamily
Documentation
data BranchFlag #
type Unbranched = Unbranched #
type BranchIndex = Int #
manyBranches :: [CoAxBranch] -> Branches Branched #
unbranched :: CoAxBranch -> Branches Unbranched #
fromBranches :: Branches br -> [CoAxBranch] #
numBranches :: Branches br -> Int #
mapAccumBranches :: ([CoAxBranch] -> CoAxBranch -> CoAxBranch) -> Branches br -> Branches br #
The [CoAxBranch]
passed into the mapping function is a list of
all previous branches, reversed
A CoAxiom
is a "coercion constructor", i.e. a named equality axiom.
CoAxiom | |
|
data CoAxBranch #
toBranchedAxiom :: CoAxiom br -> CoAxiom Branched #
toUnbranchedAxiom :: CoAxiom br -> CoAxiom Unbranched #
coAxiomName :: CoAxiom br -> Name #
coAxiomArity :: CoAxiom br -> BranchIndex -> Arity #
coAxiomBranches :: CoAxiom br -> Branches br #
coAxiomTyCon :: CoAxiom br -> TyCon #
isImplicitCoAxiom :: CoAxiom br -> Bool #
coAxiomNumPats :: CoAxiom br -> Int #
coAxiomNthBranch :: CoAxiom br -> BranchIndex -> CoAxBranch #
coAxiomSingleBranch_maybe :: CoAxiom br -> Maybe CoAxBranch #
coAxiomRole :: CoAxiom br -> Role #
coAxBranchTyVars :: CoAxBranch -> [TyVar] #
coAxBranchCoVars :: CoAxBranch -> [CoVar] #
coAxBranchRoles :: CoAxBranch -> [Role] #
coAxBranchLHS :: CoAxBranch -> [Type] #
coAxBranchRHS :: CoAxBranch -> Type #
coAxBranchSpan :: CoAxBranch -> SrcSpan #
coAxBranchIncomps :: CoAxBranch -> [CoAxBranch] #
fsFromRole :: Role -> FastString #
data CoAxiomRule #
For now, we work only with nominal equality.
CoAxiomRule | |
|
data BuiltInSynFamily #
BuiltInSynFamily | |
|