[commit: ghc] ghc-8.2: Further document :type +v's role in analyzing -XTypeApplications in GHCi (7596efd)
git at git.haskell.org
git at git.haskell.org
Wed Mar 15 15:44:09 UTC 2017
Repository : ssh://git@git.haskell.org/ghc
On branch : ghc-8.2
Link : http://ghc.haskell.org/trac/ghc/changeset/7596efd6d253c28abc663e7fac2b01442832a89e/ghc
>---------------------------------------------------------------
commit 7596efd6d253c28abc663e7fac2b01442832a89e
Author: Ryan Scott <ryan.gl.scott at gmail.com>
Date: Tue Mar 14 10:58:41 2017 -0400
Further document :type +v's role in analyzing -XTypeApplications in GHCi
Summary:
The section on `-XTypeApplications` in the users' guide isn't terribly
clear on how to view the visibility of a function type signature's type
variables in GHCi properly (i.e., using the `:type +v` GHCi command). This
adds some more exposition that demonstrates how to use `:type +v` (and why you
don't want to use `:type`).
Fixes #13401.
Test Plan: Eyeball it
Reviewers: bgamari, austin, goldfire, crockeea
Reviewed By: goldfire, crockeea
Subscribers: rwbarton, thomie, crockeea
Differential Revision: https://phabricator.haskell.org/D3310
(cherry picked from commit b335f506f1d3a766de849e015f6732ae130247a4)
>---------------------------------------------------------------
7596efd6d253c28abc663e7fac2b01442832a89e
docs/users_guide/ghci.rst | 2 +-
docs/users_guide/glasgow_exts.rst | 43 ++++++++++++++++++++++++++++++++++++---
2 files changed, 41 insertions(+), 4 deletions(-)
diff --git a/docs/users_guide/ghci.rst b/docs/users_guide/ghci.rst
index 864ae80..2d27c26 100644
--- a/docs/users_guide/ghci.rst
+++ b/docs/users_guide/ghci.rst
@@ -2724,7 +2724,7 @@ commonly used commands.
*X> :type length
length :: Foldable t => t a -> Int
-.. ghci-cmd:: :type +v ⟨expression⟩
+.. ghci-cmd:: :type +v; ⟨expression⟩
Infers and prints the type of ⟨expression⟩, but without fiddling
with type variables or class constraints. This is useful when you
diff --git a/docs/users_guide/glasgow_exts.rst b/docs/users_guide/glasgow_exts.rst
index ef2a735..0e8e956 100644
--- a/docs/users_guide/glasgow_exts.rst
+++ b/docs/users_guide/glasgow_exts.rst
@@ -9309,9 +9309,46 @@ Here are the details:
- When printing types with :ghc-flag:`-fprint-explicit-foralls` enabled,
type variables not available for visible type application are printed
- in braces. Thus, if you write ``myLength = length`` without a type
- signature, ``myLength``'s inferred type will be
- ``forall {f} {a}. Foldable f => f a -> Int``.
+ in braces. We can observe this behavior in a GHCi session: ::
+
+ > :set -XTypeApplications -fprint-explicit-foralls
+ > let myLength1 :: Foldable f => f a -> Int; myLength1 = length
+ > :type +v myLength1
+ myLength1 :: forall (f :: * -> *) a. Foldable f => f a -> Int
+ > let myLength2 = length
+ > :type +v myLength2
+ myLength2 :: forall {a} {t :: * -> *}. Foldable t => t a -> Int
+ > :type +v myLength2 @[]
+
+ <interactive>:1:1: error:
+ • Cannot apply expression of type ‘t0 a0 -> Int’
+ to a visible type argument ‘[]’
+ • In the expression: myLength2 @[]
+
+ Notice that since ``myLength1`` was defined with an explicit type signature,
+ :ghci-cmd:`:type +v` reports that all of its type variables are available
+ for type application. On the other hand, ``myLength2`` was not given a type
+ signature. As a result, all of its type variables are surrounded with braces,
+ and trying to use visible type application with ``myLength2`` fails.
+
+ Also note the use of :ghci-cmd:`:type +v` in the GHCi session above instead
+ of :ghci-cmd:`:type`. This is because :ghci-cmd:`:type` gives you the type
+ that would be inferred for a variable assigned to the expression provided
+ (that is, the type of ``x`` in ``let x = <expr>``). As we saw above with
+ ``myLength2``, this type will have no variables available to visible type
+ application. On the other hand, :ghci-cmd:`:type +v` gives you the actual
+ type of the expression provided. To illustrate this: ::
+
+ > :type myLength1
+ myLength1 :: forall {a} {f :: * -> *}. Foldable f => f a -> Int
+ > :type myLength2
+ myLength2 :: forall {a} {t :: * -> *}. Foldable t => t a -> Int
+
+ Using :ghci-cmd:`:type` might lead one to conclude that none of the type
+ variables in ``myLength1``'s type signature are available for type
+ application. This isn't true, however! Be sure to use :ghci-cmd:`:type +v`
+ if you want the most accurate information with respect to visible type
+ application properties.
- Data constructors declared with GADT syntax follow different rules
for the time being; it is expected that these will be brought in line
More information about the ghc-commits
mailing list