{- monadic stuff
 -
 - Copyright 2010-2012 Joey Hess <id@joeyh.name>
 -
 - License: BSD-2-clause
 -}

{-# OPTIONS_GHC -fno-warn-tabs #-}

module Utility.Monad where

{- if with a monadic conditional. -}
ifM :: Monad m => m Bool -> (m a, m a) -> m a
ifM :: forall (m :: * -> *) a. Monad m => m Bool -> (m a, m a) -> m a
ifM m Bool
cond (m a
thenclause, m a
elseclause) = do
	Bool
c <- m Bool
cond
	if Bool
c then m a
thenclause else m a
elseclause

{- do nothing -}
noop :: Monad m => m ()
noop :: forall (m :: * -> *). Monad m => m ()
noop = () -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()