deriving...
Simon Peyton-Jones
simonpj at microsoft.com
Tue Oct 19 10:33:25 EDT 2004
Thanks to those who responded to this thread about 'deriving'. My current thoughts are:
* I'd be happy to add the ability to separate a 'deriving' clause
from its data type declaration, if we can agree syntax
(see below). It's fairly easy to do; it makes the language more
orthogonal; it's useful.
But in fact I think only Martin Sjögren has explicitly said that
the feature would be useful.... and every feature has a cost.
* I'm not at all keen on making '..deriving( Foo )' mean
$(derive 'Foo) or something like that. Just make the TH
call yourself!
* No one is arguing hard for instance declarations in hi-boot
files, so let's leave that for now.
Re syntax, the obvious possibility (A) is to add
derive( pred1, .., predn )
as a new top-level declaration. E.g.
derive( Typeable (T a) )
But that means adding 'derive' as a keyword. Other possibilities:
deriving( Typeable (T a) )
-- (B) Re-use 'deriving' keyword
The trouble with (B) is that the thing inside the parens is different in this situation than in a data type declaration.
Any other ideas?
Simon
More information about the Glasgow-haskell-users
mailing list