After some deliberation on this I think I also come down -1 on this proposal.

default-extensions: AutoDeriveTypeable 

doesn't need it, so there is no technical reason to encumber everyone with it. It'd cause a huge spate of warnings that'd force everyone to mangle their import list in different ways with CPP, and without the methods for working with it most users'd have to import more from Data.Typeable anyways.

-Edward



On Thu, Sep 11, 2014 at 6:20 AM, Herbert Valerio Riedel <hvr@gnu.org> wrote:

TL;DR
=====

Re-export 'Data.Typeable.Typeable' from 'Prelude'

Motivation
==========

Since GHC 7.8 the ubiquitous 'Typeable' instances can only be
auto-derived via `... deriving Typeable`, moreover there's a new
extension `-XAutoDeriveTypeable` which implicitly auto-derives
'Typeable' for all defined types in modules for which that extension is
enabled.

However, even if you enable `-XAutoDeriveTypeable` you still need to
explicitly bring the 'Typeable' class into scope, with e.g.

    import Data.Typeable (Typeable)

otherwise GHC complains with

    Not in scope: type constructor or class ‘Typeable’

Since at this point it's become current practice to have 'Typeable'
instances for most types, it would be beneficial to save an 'import
Data.Typeable (Typeable)' line for the sole purpose of deriving such
instances.

By having 'Prelude' re-export 'Typeable' from GHC 7.10 on (should this
proposal be implemented) it would suffice to have a

  default-extensions: -XAutoDeriveTypeable`

in the Cabal file and have 'Typeable' instance auto-derived for all
types defined in a package w/o any source changes (unless there's a
name-clash with 'Typeable')

Discussion period
=================

The usual 2 weeks
_______________________________________________
Libraries mailing list
Libraries@haskell.org
http://www.haskell.org/mailman/listinfo/libraries