{-# LANGUAGE DeriveFunctor #-} {-# LANGUAGE FlexibleContexts #-} {-| Module : Control.Monad.Freer.Coroutine Description : Composable coroutine effects layer. Copyright : Alej Cabrera 2015 License : BSD-3 Maintainer : cpp.cabrera@gmail.com Stability : broken Portability : POSIX An effect to compose functions with the ability to yield. Using as a starting point. -} module Control.Monad.Freer.Coroutine ( Yield, yield, Status(..) ) where import Control.Monad.Freer.Internal -- | A type representing a yielding of control -- a: The current type -- b: The input to the continuation function -- v: The output of the continuation data Yield a b v = Yield a (b -> v) deriving (Functor) -- | Lifts a value and a function into the Coroutine effect yield :: (Member (Yield a b) r) => a -> (b -> c) -> Eff r c yield x f = send (Yield x f) -- | -- Status of a thread: done or reporting the value of the type a and -- resuming with the value of type b data Status r a b = Done | Continue a (b -> Eff r (Status r a b)) {- FIXME: this does not compile -- Launch a thread and report its status runC :: Eff (Yield a b ': r) w -> Eff r (Y r a b) runC m = loop m where loop :: Monad m => Eff a b -> m (Y r c d) loop (Val _) = return Done loop (E u u') = handleRelay u loop $ \(Yield x k) -> return (Y x (loop . k)) -}