[commit: ghc] master: Explain higher-kinded Coerctions in Note [Coercible Instances] (6200809)
git at git.haskell.org
git at git.haskell.org
Wed Nov 20 09:38:54 UTC 2013
Repository : ssh://git@git.haskell.org/ghc
On branch : master
Link : http://ghc.haskell.org/trac/ghc/changeset/6200809210bcca734092a1524665b7bce0239203/ghc
>---------------------------------------------------------------
commit 6200809210bcca734092a1524665b7bce0239203
Author: Joachim Breitner <mail at joachim-breitner.de>
Date: Tue Nov 19 17:11:08 2013 +0000
Explain higher-kinded Coerctions in Note [Coercible Instances]
(although there is not really a lot to explain, it seems.)
>---------------------------------------------------------------
6200809210bcca734092a1524665b7bce0239203
compiler/typecheck/TcInteract.lhs | 16 +++++++++++++++-
1 file changed, 15 insertions(+), 1 deletion(-)
diff --git a/compiler/typecheck/TcInteract.lhs b/compiler/typecheck/TcInteract.lhs
index d8abaee..48ac7dd 100644
--- a/compiler/typecheck/TcInteract.lhs
+++ b/compiler/typecheck/TcInteract.lhs
@@ -2018,7 +2018,8 @@ their evidence out of thin air, in getCoercibleInst. The following “instances
are present:
1. instance Coercible a a
- for any type a.
+ for any type a at any kind k.
+
2. instance (Coercible t1_r t1'_r, Coercible t2_r t2_r',...) =>
Coercible (C t1_r t2_r ... t1_p t2_p ... t1_n t2_n ...)
(C t1_r' t2_r' ... t1_p' t2_p' ... t1_n t2_n ...)
@@ -2026,11 +2027,16 @@ are present:
* the nominal type arguments are not changed,
* the phantom type arguments may change arbitrarily
* the representational type arguments are again Coercible
+
+ The type constructor can be used undersaturated; then the Coercible
+ instance is at a higher kind. This does not cause problems.
+
Furthermore in Safe Haskell code, we check that
* the data constructors of C are in scope and
* the data constructors of all type constructors used in the definition of C are in scope.
This is required as otherwise the previous check can be circumvented by
just adding a local data type around C.
+
3. instance Coercible r b => Coercible (NT t1 t2 ...) b
instance Coercible a r => Coercible a (NT t1 t2 ...)
for a newtype constructor NT where
@@ -2038,6 +2044,14 @@ are present:
* r is the concrete type of NT, instantiated with the arguments t1 t2 ...
* the data constructors of NT are in scope.
+ Again, the newtype TyCon can appear undersaturated, but only if it has
+ enough arguments to apply the newtype coercion (which is eta-reduced). Examples:
+ newtype NT a = NT (Either a Int)
+ Coercible (NT Int) (Either Int Int) -- ok
+ newtype NT2 a b = NT2 (b -> a)
+ newtype NT3 a b = NT3 (b -> a)
+ Coercible (NT2 Int) (NT3 Int) -- cannot be derived
+
These three shapes of instances correspond to the three constructors of
EvCoercible (defined in EvEvidence). They are assembled here and turned to Core
by dsEvTerm in DsBinds.
More information about the ghc-commits
mailing list