[ghc-steering-committee] Discussion on #155 Type Variable in Labmdas
Simon Peyton Jones
simonpj at microsoft.com
Tue Mar 5 16:34:26 UTC 2019
I haven't thought through the consequences of this fully, but it does seem plausible.
It says we must generalise over some ‘a’, but which ‘a’? What type does (\@a (\x. x)) have? I suppose you could say (forall b. (forall a. b -> b)), but presumably it could equally well have the type (forall a. a->a).
I think I can see an algorithm. But someone would need to write down a type system.
(I think I was probably was wrong to mutter about impredicativity.)
Simon
From: ghc-steering-committee <ghc-steering-committee-bounces at haskell.org> On Behalf Of Richard Eisenberg
Sent: 05 March 2019 03:06
To: Eric Seidel <eric at seidel.io>
Cc: ghc-steering-committee at haskell.org
Subject: Re: [ghc-steering-committee] Discussion on #155 Type Variable in Labmdas
On Mar 3, 2019, at 8:44 PM, Eric Seidel <eric at seidel.io<mailto:eric at seidel.io>> wrote:
Why not say that `\ @a -> body` infers the type `forall a. ty` where `body :: ty`, and let unification handle the rest?
That's intriguingly simple. I haven't thought through the consequences of this fully, but it does seem plausible. I'm not ready to commit to that, but after a few minutes' focused thought, I can't see any problems with it. In any case, the proposal as written is forward-compatible with such a change, as doing what you say will allow only more programs: ones accepted by the proposal will remain accepted and with the same meanings.
Richard
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.haskell.org/pipermail/ghc-steering-committee/attachments/20190305/1718616c/attachment-0001.html>
More information about the ghc-steering-committee
mailing list