{-# OPTIONS_GHC -fno-warn-orphans #-} -- | -- Copyright : (c) Ivan Perez and Manuel Baerenz, 2016 -- License : BSD3 -- Maintainer : ivan.perez@keera.co.uk -- -- Instance of 'ArrowPlus' for Monadic Stream Functions ('MSF'). -- -- Import this module to include that (orphan) instance. -- -- This is only defined for monads that are instances of 'MonadPlus'. module Data.MonadicStreamFunction.Instances.ArrowPlus where -- base import Control.Applicative import Control.Arrow import Control.Monad -- dunai import Data.MonadicStreamFunction.Core import Data.MonadicStreamFunction.InternalCore -- | Instance of 'ArrowZero' for Monadic Stream Functions ('MSF'). -- The monad must be an instance of 'MonadPlus'. instance (Monad m, MonadPlus m) => ArrowZero (MSF m) where zeroArrow = MSF $ const mzero -- | Instance of 'ArrowPlus' for Monadic Stream Functions ('MSF'). -- The monad must be an instance of 'MonadPlus'. instance (Monad m, MonadPlus m) => ArrowPlus (MSF m) where sf1 <+> sf2 = MSF $ \a -> unMSF sf1 a `mplus` unMSF sf2 a instance (Functor m, Monad m, MonadPlus m) => Alternative (MSF m a) where empty = zeroArrow (<|>) = (<+>)