Safe Haskell | Trustworthy |
---|---|
Language | Haskell2010 |
Functional channels | A channel data type which allows consumers to hold references to different points in a stream at the same time. Elements of a channel are kept alive only so long as there are references pointing before those elements; producers on a channel are kept alive only so long as there are consumers.
Synopsis
- data Chan t
- listToChan :: [t] -> Chan t
- chanContents :: Chan t -> IO [t]
- data DoneReadingException = DoneReadingException
- takeChan :: Chan t -> IO (t, Chan t)
- tryTakeChan :: Chan t -> IO (Maybe (t, Chan t))
- newChan :: IO (t -> IO (), Chan t)
- makeConsumer :: Chan b -> IO (IO b, IO (Chan b))
- dupChan :: Chan a -> IO (Chan a)
Documentation
listToChan :: [t] -> Chan t Source #
Construct a channel from a list.
chanContents :: Chan t -> IO [t] Source #
data DoneReadingException Source #
Thrown by the writer function.
Instances
Show DoneReadingException Source # | |
Defined in Control.CUtils.FChan showsPrec :: Int -> DoneReadingException -> ShowS # show :: DoneReadingException -> String # showList :: [DoneReadingException] -> ShowS # | |
Exception DoneReadingException Source # | |
Defined in Control.CUtils.FChan |
takeChan :: Chan t -> IO (t, Chan t) Source #
Take the first element from a channel, and a channel representing the remainder of the output.
newChan :: IO (t -> IO (), Chan t) Source #
Create a new channel. The first return value is a function that can be used to add values to the channel. The second return value is the channel itself.
makeConsumer :: Chan b -> IO (IO b, IO (Chan b)) Source #
The first return value is a procedure that returns values from the channel successively, starting from the position of the parameter channel. The second thunk can be used to retrieve the position of the channel after the reads made using the first thunk.