[Haskell] A puzzle and an annoying feature
Ketil Malde
ketil+haskell at ii.uib.no
Thu Nov 25 00:34:24 EST 2004
Paul Govereau <govereau at eecs.harvard.edu> writes:
> This is a great example, thanks for posting it. However, I feel like
> the real problem in this example is the lexically-scoped type
> variables declared with your function f. I am always surprised by the
> effects that lexically-scoped type variables can have on top-level
> declarations.
I remain unpuzzled by your examples, could I ask you to elaborate?
> Consider another example:
>
> f :: a -> a
> f = \x -> x
>
> Of course, f has type (forall a. a -> a).
Yes.
> However, if we add another declaration g with lexically-scoped type
> variable a:
>
> g :: a -> a = \x -> 1
>
> Then, suddenly, f has type Integer -> Integer
Well, you say that the parameter and return value have the same type
a, and I suppose Haskell monomorphs the constant 1 to Integer. Did you
perhaps mean:
g :: a -> a = \x -> x
which has type () -> () ?
-kzm
--
If I haven't seen further, it is by standing in the footprints of giants
More information about the Haskell
mailing list