Monad
The Monad class inherits from the Applicative class (only from GHC 7.10 onward; see the Monad as applicative section for more on this):
class (Applicative m) => Monad m where return :: a -> m a (>>=) :: m a -> (a -> m b) -> m b
The return function looks just like the pure function of the Applicative class (it wraps a value in a Monad class).
The bind operator (>>=) combines a Monad (m a) with a function (a -> m b), which we'll call a monadic
function. The monadic function acts on type a of the first monad and returns a new monad of type (m b).
Let's make our Maybe' type a Monad class:
import Control.Monad import Control.Applicative data Maybe' a = Just' a | Nothing' deriving (Show) instance Functor Maybe' where –- ... instance Applicative Maybe' where –- ... instance Monad Maybe' where return x = Just' x Nothing' >>= _ = Nothing' (Just' x) >>= f ...