[Haskell-cafe] type inference and named fields

Daniel Brown danb at cs.utexas.edu
Fri Jun 24 10:39:50 EDT 2005


Jonathan Cast wrote:
> Lennart Augustsson <lennart at augustsson.net> wrote:
>>
>>foo :: Either a b -> Either () b
>>foo (Left _) = Left ()
>>foo x@(Right _) = x
>>
>>Since Haskell type checking doesn't use the information gained
>>by pattern matching to refine types we just have to accept that
>>some perfectly safe programs don't type check.
> 
> Well, not  perfectly safe.  We  already had this discussion  (about []),
> but to say it again: the  value bound by any pattern has some particular
> type.  x above doesn't have type (Either a b) for arbitrary a and b, but
> rather (Either a  b) for some specific a and b.   Unless that specific a
> happens to be (), x doesn't have  the correct type to be the rhs of foo.
> It would require a radical change to GHC (moving away from System F as a
> basis for  the intermediate  language Core) to  implement a  language in
> which this wasn't true.

I see that the argument to foo has type `Either a b` (unquantified), but 
why can't x, bound to the value that matches the pattern, have the type 
of the pattern? In this case, that would let `x :: forall x. Either x 
b`, which unifies with `Either () b`.

  Dan


More information about the Haskell-Cafe mailing list