| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
Agda.Utils.Maybe.Strict
Contents
Description
A strict version of the Maybe type.
Import qualified, as in
   
     import qualified Agda.Utils.Maybe.Strict as Strict
   
Copyright : (c) 2006-2007 Roman Leshchinskiy (c) 2013 Simon Meier License : BSD-style (see the file LICENSE)
Copyright : (c) 2014 Andreas Abel
Synopsis
- caseMaybeM :: Monad m => m (Maybe a) -> m b -> (a -> m b) -> m b
- fromMaybeM :: Monad m => m a -> m (Maybe a) -> m a
- forMaybe :: [a] -> (a -> Maybe b) -> [b]
- filterMaybe :: (a -> Bool) -> a -> Maybe a
- whenJust :: Monad m => Maybe a -> (a -> m ()) -> m ()
- unionMaybeWith :: (a -> a -> a) -> Maybe a -> Maybe a -> Maybe a
- unzipMaybe :: Maybe (a, b) -> (Maybe a, Maybe b)
- caseMaybe :: Maybe a -> b -> (a -> b) -> b
- maybeM :: Monad m => m b -> (a -> m b) -> m (Maybe a) -> m b
- ifJustM :: Monad m => m (Maybe a) -> (a -> m b) -> m b -> m b
- whenJustM :: Monad m => m (Maybe a) -> (a -> m ()) -> m ()
Documentation
caseMaybeM :: Monad m => m (Maybe a) -> m b -> (a -> m b) -> m b Source #
fromMaybeM :: Monad m => m a -> m (Maybe a) -> m a Source #
Monadic version of fromMaybe.
forMaybe :: [a] -> (a -> Maybe b) -> [b] Source #
Version of mapMaybe with different argument ordering.
filterMaybe :: (a -> Bool) -> a -> Maybe a Source #
Filtering a singleton list.
filterMaybe p a =listToMaybe(filterp [a])
unionMaybeWith :: (a -> a -> a) -> Maybe a -> Maybe a -> Maybe a Source #
unionWith for collections of size <= 1.
unzipMaybe :: Maybe (a, b) -> (Maybe a, Maybe b) Source #
Unzipping a list of length <= 1.
caseMaybe :: Maybe a -> b -> (a -> b) -> b Source #
Version of maybe with different argument ordering.
   Often, we want to case on a Maybe, do something interesting
   in the Just case, but only a default action in the Nothing
   case.  Then, the argument ordering of caseMaybe is preferable.
caseMaybe m err f = flip (maybe err) m f
ifJustM :: Monad m => m (Maybe a) -> (a -> m b) -> m b -> m b Source #
caseMaybeM with flipped branches.
whenJustM :: Monad m => m (Maybe a) -> (a -> m ()) -> m () Source #
caseMaybeM without the Nothing case.
Orphan instances
| Applicative Maybe Source # | Note that strict Maybe is an  | 
| Null (Maybe a) Source # | |