[Haskell-cafe] Class Quantification
Sean Leather
leather at cs.uu.nl
Tue Sep 30 17:26:29 EDT 2008
> Now I would like to generalise 'foo' and 'bar' to 'bla' so that I can
> write:
>
> testBla1 = bla fromInteger 1 :: (Int, Float)
> testBla2 = bla read "1" :: (Int, Float)
>
> My question is how to define 'bla'.
>
> I can write:
>
> > bla :: (forall b. a -> b) -> a -> (c, d)
> > bla f x = (f x, f x)
>
> But then 'testBla1' gives the following expected error:
>
> Could not deduce (Num b) from the context ()
> arising from a use of `fromInteger'
>
> [...]
>
> So, somehow I need to quantify over the type class.
>
> bla :: forall cls. (cls c, cls d) => (forall b. cls b => a -> b) -> a ->
> (c, d)
>
> But this isn't legal.
>
> Is there another way of defining 'bla'?
>
The simple, from-the-gut answer involves the enumeration of all the classes
that you need in the context.
> bla :: (Read c, Read d, Num c, Num d) => (forall b. (Read b, Num b) => a
-> b) -> a -> (c, d)
> bla f x = (f x, f x)
But perhaps you're looking for potentially unknown classes?
Sean
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://www.haskell.org/pipermail/haskell-cafe/attachments/20080930/68894af8/attachment.htm
More information about the Haskell-Cafe
mailing list