shithub: MicroHs

ref: 1ae3cf8839a2498525a5c9753d3c4226d88ee09e
dir: /lib/Control/Applicative.hs/

View raw version
module Control.Applicative(module Control.Applicative) where
import Primitives  -- for fixity
import Data.Functor
import Data.Function

infixl 4 <*>
infixl 4 *>
infixl 4 <*

class Functor f => Applicative f where
  pure  :: forall a . a -> f a
  (<*>) :: forall a b . f (a -> b) -> f a -> f b
  (*>)  :: forall a b . f a -> f b -> f b
  (<*)  :: forall a b . f a -> f b -> f a
  a1 *> a2 = (id <$ a1) <*> a2
  a1 <* a2 = (const <$> a1) <*> a2

liftA2 :: forall f a b c . Applicative f => (a -> b -> c) -> f a -> f b -> f c
liftA2 f a b = f <$> a <*> b

liftA3 :: forall f a b c d . Applicative f => (a -> b -> c -> d) -> f a -> f b -> f c -> f d
liftA3 f a b c = f <$> a <*> b <*> c