----------------------------------------------------------------------------- -- -- Module : Language.PureScript.Traversals -- Copyright : (c) 2014 Phil Freeman -- License : MIT -- -- Maintainer : Phil Freeman -- Stability : experimental -- Portability : -- -- | Common functions for implementing generic traversals -- ----------------------------------------------------------------------------- module Language.PureScript.Traversals where import Control.Applicative fstM :: (Functor f) => (a -> f c) -> (a, b) -> f (c, b) fstM f (a, b) = flip (,) b <$> f a sndM :: (Functor f) => (b -> f c) -> (a, b) -> f (a, c) sndM f (a, b) = (,) a <$> f b thirdM :: (Functor f) => (c -> f d) -> (a, b, c) -> f (a, b, d) thirdM f (a, b, c) = (,,) a b <$> f c maybeM :: (Applicative f) => (a -> f b) -> Maybe a -> f (Maybe b) maybeM _ Nothing = pure Nothing maybeM f (Just a) = Just <$> f a defS :: (Monad m) => st -> val -> m (st, val) defS s val = return (s, val)