summaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorSimon Peyton Jones <simonpj@microsoft.com>2017-12-18 12:03:33 +0000
committerSimon Peyton Jones <simonpj@microsoft.com>2017-12-18 15:47:19 +0000
commitf1fe5b4adf6a4094ecc600a28f64f7628903d017 (patch)
tree078df33932b6422ce520aee82c0d153fd4135a09 /docs
parent1e64fc81295ac27c5e662576da3afacd42186a13 (diff)
downloadhaskell-f1fe5b4adf6a4094ecc600a28f64f7628903d017.tar.gz
Fix scoping of pattern-synonym existentials
This patch fixes Trac #14998, where we eventually decided that the existential type variables of the signature of a pattern synonym should not scope over the pattern synonym. See Note [Pattern synonym existentials do not scope] in TcPatSyn.
Diffstat (limited to 'docs')
-rw-r--r--docs/users_guide/glasgow_exts.rst18
1 files changed, 17 insertions, 1 deletions
diff --git a/docs/users_guide/glasgow_exts.rst b/docs/users_guide/glasgow_exts.rst
index 7861a1740f..6c444cc873 100644
--- a/docs/users_guide/glasgow_exts.rst
+++ b/docs/users_guide/glasgow_exts.rst
@@ -5297,6 +5297,8 @@ Note also the following points
P :: () => CProv => t1 -> t2 -> .. -> tN -> t
+- The GHCi :ghci-cmd:`:info` command shows pattern types in this format.
+
- You may specify an explicit *pattern signature*, as we did for
``ExNumPat`` above, to specify the type of a pattern, just as you can
for a function. As usual, the type signature can be less polymorphic
@@ -5313,7 +5315,21 @@ Note also the following points
pattern Left' x = Left x
pattern Right' x = Right x
-- The GHCi :ghci-cmd:`:info` command shows pattern types in this format.
+- The rules for lexically-scoped type variables (see
+ :ref:`scoped-type-variables`) apply to pattern-synonym signatures.
+ As those rules specify, only the type variables from an explicit,
+ syntactically-visible outer `forall` (the universals) scope over
+ the definition of the pattern synonym; the existentials, bound by
+ the inner forall, do not. For example ::
+
+ data T a where
+ MkT :: Bool -> b -> (b->Int) -> a -> T a
+
+ pattern P :: forall a. forall b. b -> (b->Int) -> a -> T a
+ pattern P x y v <- MkT True x y (v::a)
+
+ Here the universal type variable `a` scopes over the definition of `P`,
+ but the existential `b` does not. (c.f. disussion on Trac #14998.)
- For a bidirectional pattern synonym, a use of the pattern synonym as
an expression has the type