Prelude

A Prelude module replacement

Latest on Hackage:0.1.0.1@rev:1

This package is not currently in any snapshots. If you're interested in using it, we recommend adding it to Stackage Nightly. Doing so will make builds more reliable, and allow stackage.org to host generated Haddocks.

BSD-3-Clause licensed by Herbert Valerio Riedel
Maintained by [email protected]

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)