[Haskell-cafe] ambiguous types although 'asTypeOf'
Henning Thielemann
lemming at henning-thielemann.de
Tue Dec 25 13:27:41 EST 2007
I thought I understand monomorphism restriction. But it seems, I don't. I
have boilt down my problem to the following test. Don't try to make any
sense of it, it is just the smallest code I could come up with.
test :: (Integral a, RealFrac a) => a
test =
let c = undefined
in asTypeOf (round c) c
When compiling I get:
Compiling StorableInstance ( src/StorableInstance.hs, interpreted )
src/StorableInstance.hs:38:17:
Warning: Defaulting the following constraint(s) to type `Double'
`RealFrac a' arising from use of `round' at src/StorableInstance.hs:38:17-21
In the first argument of `asTypeOf', namely `(round c)'
In the definition of `test1': test1 = let c = undefined in asTypeOf (round c) c
More information about the Haskell-Cafe
mailing list