| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
GHC.Core.Unify
Contents
Synopsis
- tcMatchTy :: Type -> Type -> Maybe TCvSubst
- tcMatchTyKi :: Type -> Type -> Maybe TCvSubst
- tcMatchTys :: [Type] -> [Type] -> Maybe TCvSubst
- tcMatchTyKis :: [Type] -> [Type] -> Maybe TCvSubst
- tcMatchTyX :: TCvSubst -> Type -> Type -> Maybe TCvSubst
- tcMatchTysX :: TCvSubst -> [Type] -> [Type] -> Maybe TCvSubst
- tcMatchTyKisX :: TCvSubst -> [Type] -> [Type] -> Maybe TCvSubst
- tcMatchTyX_BM :: BindFun -> TCvSubst -> Type -> Type -> Maybe TCvSubst
- ruleMatchTyKiX :: TyCoVarSet -> RnEnv2 -> TvSubstEnv -> Type -> Type -> Maybe TvSubstEnv
- data RoughMatchTc
- roughMatchTcs :: [Type] -> [RoughMatchTc]
- roughMatchTcsLookup :: [Type] -> [RoughMatchLookupTc]
- instanceCantMatch :: [RoughMatchTc] -> [RoughMatchTc] -> Bool
- typesCantMatch :: [(Type, Type)] -> Bool
- isRoughWildcard :: RoughMatchTc -> Bool
- tcUnifyTy :: Type -> Type -> Maybe TCvSubst
- tcUnifyTyKi :: Type -> Type -> Maybe TCvSubst
- tcUnifyTys :: BindFun -> [Type] -> [Type] -> Maybe TCvSubst
- tcUnifyTyKis :: BindFun -> [Type] -> [Type] -> Maybe TCvSubst
- tcUnifyTysFG :: BindFun -> [Type] -> [Type] -> UnifyResult
- tcUnifyTyWithTFs :: Bool -> Type -> Type -> Maybe TCvSubst
- type BindFun = TyCoVar -> Type -> BindFlag
- data BindFlag
- matchBindFun :: TyCoVarSet -> BindFun
- alwaysBindFun :: BindFun
- type UnifyResult = UnifyResultM TCvSubst
- data UnifyResultM a
- data MaybeApartReason
- liftCoMatch :: TyCoVarSet -> Type -> Coercion -> Maybe LiftingContext
- flattenTys :: InScopeSet -> [Type] -> [Type]
- flattenTysX :: InScopeSet -> [Type] -> ([Type], TyVarEnv (TyCon, [Type]))
Documentation
tcMatchTy :: Type -> Type -> Maybe TCvSubst Source #
tcMatchTy t1 t2 produces a substitution (over fvs(t1))
 s such that s(t1) equals t2.
 The returned substitution might bind coercion variables,
 if the variable is an argument to a GADT constructor.
Precondition: typeKind ty1 eqType typeKind ty2
We don't pass in a set of "template variables" to be bound by the match, because tcMatchTy (and similar functions) are always used on top-level types, so we can bind any of the free variables of the LHS. See also Note [tcMatchTy vs tcMatchTyKi]
tcMatchTyKi :: Type -> Type -> Maybe TCvSubst Source #
Like tcMatchTy, but allows the kinds of the types to differ,
 and thus matches them as well.
 See also Note [tcMatchTy vs tcMatchTyKi]
Arguments
| :: [Type] | Template | 
| -> [Type] | Target | 
| -> Maybe TCvSubst | One-shot; in principle the template variables could be free in the target | 
Like tcMatchTy but over a list of types.
 See also Note [tcMatchTy vs tcMatchTyKi]
Like tcMatchTyKi but over a list of types.
 See also Note [tcMatchTy vs tcMatchTyKi]
This is similar to tcMatchTy, but extends a substitution
 See also Note [tcMatchTy vs tcMatchTyKi]
Arguments
| :: TCvSubst | Substitution to extend | 
| -> [Type] | Template | 
| -> [Type] | Target | 
| -> Maybe TCvSubst | One-shot substitution | 
Like tcMatchTys, but extending a substitution
 See also Note [tcMatchTy vs tcMatchTyKi]
Arguments
| :: TCvSubst | Substitution to extend | 
| -> [Type] | Template | 
| -> [Type] | Target | 
| -> Maybe TCvSubst | One-shot substitution | 
Like tcMatchTyKis, but extending a substitution
 See also Note [tcMatchTy vs tcMatchTyKi]
Arguments
| :: TyCoVarSet | template variables | 
| -> RnEnv2 | |
| -> TvSubstEnv | type substitution to extend | 
| -> Type | Template | 
| -> Type | Target | 
| -> Maybe TvSubstEnv | 
This one is called from the expression matcher, which already has a MatchEnv in hand
Rough matching
data RoughMatchTc Source #
Constructors
| RM_KnownTc Name | |
| RM_WildCard | 
Instances
| Data RoughMatchTc Source # | |
| Defined in GHC.Core.RoughMap Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> RoughMatchTc -> c RoughMatchTc Source # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c RoughMatchTc Source # toConstr :: RoughMatchTc -> Constr Source # dataTypeOf :: RoughMatchTc -> DataType Source # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c RoughMatchTc) Source # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c RoughMatchTc) Source # gmapT :: (forall b. Data b => b -> b) -> RoughMatchTc -> RoughMatchTc Source # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> RoughMatchTc -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> RoughMatchTc -> r Source # gmapQ :: (forall d. Data d => d -> u) -> RoughMatchTc -> [u] Source # gmapQi :: Int -> (forall d. Data d => d -> u) -> RoughMatchTc -> u Source # gmapM :: Monad m => (forall d. Data d => d -> m d) -> RoughMatchTc -> m RoughMatchTc Source # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> RoughMatchTc -> m RoughMatchTc Source # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> RoughMatchTc -> m RoughMatchTc Source # | |
| Outputable RoughMatchTc Source # | |
| Defined in GHC.Core.RoughMap Methods ppr :: RoughMatchTc -> SDoc Source # | |
roughMatchTcs :: [Type] -> [RoughMatchTc] Source #
roughMatchTcsLookup :: [Type] -> [RoughMatchLookupTc] Source #
instanceCantMatch :: [RoughMatchTc] -> [RoughMatchTc] -> Bool Source #
typesCantMatch :: [(Type, Type)] -> Bool Source #
Given a list of pairs of types, are any two members of a pair surely apart, even after arbitrary type function evaluation and substitution?
isRoughWildcard :: RoughMatchTc -> Bool Source #
tcUnifyTy :: Type -> Type -> Maybe TCvSubst Source #
Simple unification of two types; all type variables are bindable Precondition: the kinds are already equal
tcUnifyTyKis :: BindFun -> [Type] -> [Type] -> Maybe TCvSubst Source #
Like tcUnifyTys but also unifies the kinds
tcUnifyTysFG :: BindFun -> [Type] -> [Type] -> UnifyResult Source #
tcUnifyTysFG bind_tv tys1 tys2 attempts to find a substitution s (whose
 domain elements all respond BindMe to bind_tv) such that
 s(tys1) and that of s(tys2) are equal, as witnessed by the returned
 Coercions. This version requires that the kinds of the types are the same,
 if you unify left-to-right.
Arguments
| :: Bool | True = do two-way unification; False = do one-way matching. See end of sec 5.2 from the paper | 
| -> Type | |
| -> Type | |
| -> Maybe TCvSubst | 
Unify two types, treating type family applications as possibly unifying with anything and looking through injective type family applications. Precondition: kinds are the same
type BindFun = TyCoVar -> Type -> BindFlag Source #
Some unification functions are parameterised by a BindFun, which
 says whether or not to allow a certain unification to take place.
 A BindFun takes the TyVar involved along with the Type it will
 potentially be bound to.
It is possible for the variable to actually be a coercion variable
 (Note [Matching coercion variables]), but only when one-way matching.
 In this case, the Type will be a CoercionTy.
matchBindFun :: TyCoVarSet -> BindFun Source #
Allow binding only for any variable in the set. Variables may be bound to any type. Used when doing simple matching; e.g. can we find a substitution
S = [a :-> t1, b :-> t2] such that
    S( Maybe (a, b->Int )  =   Maybe (Bool, Char -> Int)
alwaysBindFun :: BindFun Source #
Allow the binding of any variable to any type
type UnifyResult = UnifyResultM TCvSubst Source #
data UnifyResultM a Source #
See Note [Unification result]
Constructors
| Unifiable a | |
| MaybeApart MaybeApartReason a | |
| SurelyApart | 
Instances
| Applicative UnifyResultM Source # | |
| Defined in GHC.Core.Unify Methods pure :: a -> UnifyResultM a Source # (<*>) :: UnifyResultM (a -> b) -> UnifyResultM a -> UnifyResultM b Source # liftA2 :: (a -> b -> c) -> UnifyResultM a -> UnifyResultM b -> UnifyResultM c Source # (*>) :: UnifyResultM a -> UnifyResultM b -> UnifyResultM b Source # (<*) :: UnifyResultM a -> UnifyResultM b -> UnifyResultM a Source # | |
| Functor UnifyResultM Source # | |
| Defined in GHC.Core.Unify Methods fmap :: (a -> b) -> UnifyResultM a -> UnifyResultM b Source # (<$) :: a -> UnifyResultM b -> UnifyResultM a Source # | |
| Monad UnifyResultM Source # | |
| Defined in GHC.Core.Unify Methods (>>=) :: UnifyResultM a -> (a -> UnifyResultM b) -> UnifyResultM b Source # (>>) :: UnifyResultM a -> UnifyResultM b -> UnifyResultM b Source # return :: a -> UnifyResultM a Source # | |
| Outputable a => Outputable (UnifyResultM a) Source # | |
| Defined in GHC.Core.Unify Methods ppr :: UnifyResultM a -> SDoc Source # | |
data MaybeApartReason Source #
Why are two types MaybeApart? MARInfinite takes precedence:
 This is used (only) in Note [Infinitary substitution in lookup] in GHC.Core.InstEnv
 As of Feb 2022, we never differentiate between MARTypeFamily and MARTypeVsConstraint;
 it's really only MARInfinite that's interesting here.
Constructors
| MARTypeFamily | matching e.g. F Int ~? Bool | 
| MARInfinite | matching e.g. a ~? Maybe a | 
| MARTypeVsConstraint | matching Type ~? Constraint See Note [coreView vs tcView] in GHC.Core.Type | 
Instances
| Semigroup MaybeApartReason Source # | |
| Defined in GHC.Core.Unify Methods (<>) :: MaybeApartReason -> MaybeApartReason -> MaybeApartReason Source # sconcat :: NonEmpty MaybeApartReason -> MaybeApartReason Source # stimes :: Integral b => b -> MaybeApartReason -> MaybeApartReason Source # | |
| Outputable MaybeApartReason Source # | |
| Defined in GHC.Core.Unify Methods ppr :: MaybeApartReason -> SDoc Source # | |
liftCoMatch :: TyCoVarSet -> Type -> Coercion -> Maybe LiftingContext Source #
liftCoMatch is sort of inverse to liftCoSubst.  In particular, if
   liftCoMatch vars ty co == Just s, then liftCoSubst s ty == co,
   where == there means that the result of liftCoSubst has the same
   type as the original co; but may be different under the hood.
   That is, it matches a type against a coercion of the same
   "shape", and returns a lifting substitution which could have been
   used to produce the given coercion from the given type.
   Note that this function is incomplete -- it might return Nothing
   when there does indeed exist a possible lifting context.
This function is incomplete in that it doesn't respect the equality
 in eqType. That is, it's possible that this will succeed for t1 and
 fail for t2, even when t1 eqType t2. That's because it depends on
 there being a very similar structure between the type and the coercion.
 This incompleteness shouldn't be all that surprising, especially because
 it depends on the structure of the coercion, which is a silly thing to do.
The lifting context produced doesn't have to be exacting in the roles of the mappings. This is because any use of the lifting context will also require a desired role. Thus, this algorithm prefers mapping to nominal coercions where it can do so.
flattenTys :: InScopeSet -> [Type] -> [Type] Source #
flattenTysX :: InScopeSet -> [Type] -> ([Type], TyVarEnv (TyCon, [Type])) Source #