summaryrefslogtreecommitdiff
path: root/libraries/base
diff options
context:
space:
mode:
authorHerbert Valerio Riedel <hvr@gnu.org>2014-10-05 15:18:49 +0200
committerHerbert Valerio Riedel <hvr@gnu.org>2014-11-10 21:47:03 +0100
commit87101364e0c2db5e472c6331ad35503028b2ec3c (patch)
tree785b20e79a5bc78e2a846b45d93aab569a15b494 /libraries/base
parente2769df912672d39346727616750ba8066e489f9 (diff)
downloadhaskell-87101364e0c2db5e472c6331ad35503028b2ec3c.tar.gz
Move Data.Functor.Identity from transformers to base
This also updates the `transformers` submodule to the just released `transformers-0.4.2.0` package version. See #9664 for more details Reviewed By: austin, ekmett Differential Revision: https://phabricator.haskell.org/D313
Diffstat (limited to 'libraries/base')
-rw-r--r--libraries/base/Data/Functor/Identity.hs75
-rw-r--r--libraries/base/base.cabal1
-rw-r--r--libraries/base/changelog.md3
3 files changed, 79 insertions, 0 deletions
diff --git a/libraries/base/Data/Functor/Identity.hs b/libraries/base/Data/Functor/Identity.hs
new file mode 100644
index 0000000000..4058df8824
--- /dev/null
+++ b/libraries/base/Data/Functor/Identity.hs
@@ -0,0 +1,75 @@
+{-# LANGUAGE CPP #-}
+{-# LANGUAGE AutoDeriveTypeable #-}
+-----------------------------------------------------------------------------
+-- |
+-- Module : Data.Functor.Identity
+-- Copyright : (c) Andy Gill 2001,
+-- (c) Oregon Graduate Institute of Science and Technology 2001
+-- License : BSD-style (see the file LICENSE)
+--
+-- Maintainer : ross@soi.city.ac.uk
+-- Stability : experimental
+-- Portability : portable
+--
+-- The identity functor and monad.
+--
+-- This trivial type constructor serves two purposes:
+--
+-- * It can be used with functions parameterized by functor or monad classes.
+--
+-- * It can be used as a base monad to which a series of monad
+-- transformers may be applied to construct a composite monad.
+-- Most monad transformer modules include the special case of
+-- applying the transformer to 'Identity'. For example, @State s@
+-- is an abbreviation for @StateT s 'Identity'@.
+--
+-- /Since: 4.8.0.0/
+-----------------------------------------------------------------------------
+
+module Data.Functor.Identity (
+ Identity(..),
+ ) where
+
+import Control.Monad.Fix
+import Data.Functor
+
+-- | Identity functor and monad. (a non-strict monad)
+--
+-- /Since: 4.8.0.0/
+newtype Identity a = Identity { runIdentity :: a }
+ deriving (Eq, Ord)
+
+-- | This instance would be equivalent to the derived instances of the
+-- 'Identity' newtype if the 'runIdentity' field were removed
+instance (Read a) => Read (Identity a) where
+ readsPrec d = readParen (d > 10) $ \ r ->
+ [(Identity x,t) | ("Identity",s) <- lex r, (x,t) <- readsPrec 11 s]
+
+-- | This instance would be equivalent to the derived instances of the
+-- 'Identity' newtype if the 'runIdentity' field were removed
+instance (Show a) => Show (Identity a) where
+ showsPrec d (Identity x) = showParen (d > 10) $
+ showString "Identity " . showsPrec 11 x
+
+-- ---------------------------------------------------------------------------
+-- Identity instances for Functor and Monad
+
+instance Functor Identity where
+ fmap f m = Identity (f (runIdentity m))
+
+instance Foldable Identity where
+ foldMap f (Identity x) = f x
+
+instance Traversable Identity where
+ traverse f (Identity x) = Identity <$> f x
+
+instance Applicative Identity where
+ pure a = Identity a
+ Identity f <*> Identity x = Identity (f x)
+
+instance Monad Identity where
+ return a = Identity a
+ m >>= k = k (runIdentity m)
+
+instance MonadFix Identity where
+ mfix f = Identity (fix (runIdentity . f))
diff --git a/libraries/base/base.cabal b/libraries/base/base.cabal
index 6277d89e79..7e5ca15476 100644
--- a/libraries/base/base.cabal
+++ b/libraries/base/base.cabal
@@ -130,6 +130,7 @@ Library
Data.Foldable
Data.Function
Data.Functor
+ Data.Functor.Identity
Data.IORef
Data.Int
Data.Ix
diff --git a/libraries/base/changelog.md b/libraries/base/changelog.md
index 2fa25ae06e..c5047ce986 100644
--- a/libraries/base/changelog.md
+++ b/libraries/base/changelog.md
@@ -97,6 +97,9 @@
are swapped, such that `Data.List.nubBy (<) [1,2]` now returns `[1]`
instead of `[1,2]` (#2528, #3280, #7913)
+ * New module `Data.Functor.Identity` (previously provided by `transformers`
+ package). (#9664)
+
## 4.7.0.1 *Jul 2014*
* Bundled with GHC 7.8.3