This package provides a Prelude module drop-in replacement for base's Prelude module.
Goals of this package include:
Be reasonably modest and remain close in spirit to the base package's scope
Depend only on base (via base-noprelude) for recent GHC versions
Avoid partial functions being in scope by default; redefine common partial functions such as read or head to be Maybe-valued
Provide a uniform Prelude across multiple GHC releases (currently GHC 7.0 and newer supported) to the extent possible given typeclass restructurings such as AMP or FTP
Reduce import clutter by reexporting common verbs from modules such as Control.Monad and Control.Applicative
Versioning and Usage
This package is intended to be used in combination with base-noprelude and
possibly base-orphans. Prelude strives to be faithful to
the PVP; however, for technical reasons Prelude's API is not fully determined by its version due to changes in core typeclasses and consequently it's strongly advised to declare a dependency on Prelude always in conjunction with a dependency on base-noprelude.
For instance, all you need to do in order to use this package if you were previously depending on base via
build-depends:
base (>= 4.3.0.0 && < 4.11) || ^>= 4.11.0.0
is to replace base by base-noprelude and also add a dependency on Prelude like so
build-depends:
Prelude ^>= 0.1.0.0
, base-noprelude (>= 4.3.0.0 && < 4.11) || ^>= 4.11.0.0
and this will effectively replace the implicit Prelude module.
Alternatively, if you only intend to support GHC 7.10 and newer, you can make use mixins like so
build-depends:
Prelude ^>= 0.1.0.0
, base (>= 4.8.0.0 && < 4.12) || ^>= 4.12.0.0
mixins: base hiding (Prelude)