-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | Effectful streaming library based on shortcut fusion techniques -- @package fusion @version 0.1.1 module Fusion -- | A simple stepper, as suggested by Duncan Coutts in his Thesis paper, -- "Stream Fusion: Practical shortcut fusion for coinductive sequence -- types". This version adds a result type. data Step s a r Done :: r -> Step s a r Skip :: s -> Step s a r Yield :: s -> a -> Step s a r newtype StepList s r a StepList :: Step s a r -> StepList s r a getStepList :: StepList s r a -> Step s a r data Stream a m r Stream :: (s -> m (Step s a r)) -> m s -> Stream a m r -- | Map over the values produced by a stream. -- --
-- >>> mapS (+1) (fromList [1..3]) :: Stream Int Identity () -- Stream [2,3,4] --mapS :: Functor m => (a -> b) -> Stream a m r -> Stream b m r concatS :: Monad m => Stream (Stream a m r) m r -> Stream a m r fromList :: Foldable f => Applicative m => f a -> Stream a m () fromListM :: (Monad m, Foldable f) => m (f a) -> Stream a m () toListS :: Monad m => Stream a m r -> m [a] lazyToListS :: Stream a IO r -> IO [a] runEffect :: Monad m => Stream a m r -> m r emptyStream :: (Monad m, Applicative m) => Stream Void m () bracketS :: (Monad m, MonadMask m, MonadSafe m) => Base m s -> (s -> Base m ()) -> (forall r. s -> (a -> s -> m r) -> (s -> m r) -> m r -> m r) -> Stream a m () next :: Monad m => Stream a m r -> m (Either r (a, Stream a m r)) newtype ListT m a ListT :: Stream a m () -> ListT m a getListT :: ListT m a -> Stream a m () concatL :: (Monad m, Applicative m) => ListT m (ListT m a) -> ListT m a type Producer b m r = Stream b m r type Pipe a b m r = Stream a m () -> Stream b m r type Consumer a m r = Stream a m () -> m r each :: (Applicative m, Foldable f) => f a -> Producer a m () mapP :: (Monad m, Applicative m) => (a -> b) -> Pipe a b m () instance Functor (Step s a) instance (Monad m, Applicative m) => Monad (ListT m) instance (Monad m, Applicative m) => Applicative (ListT m) instance Functor m => Functor (ListT m) instance MonadTrans (Stream a) instance (Monad m, Applicative m) => Applicative (Stream a m) instance Functor m => Functor (Stream a m) instance Show a => Show (Stream a Identity r) instance Functor (StepList s r)