Picos_std_sync.StreamA lock-free, poisonable, many-to-many, stream.
Readers can tap into a stream to get a cursor for reading all the values pushed to the stream starting from the cursor position. Conversely, values pushed to a stream are lost unless a reader has a cursor to the position in the stream.
val create : ?padded:bool -> unit -> 'a tcreate () returns a new stream.
val push : 'a t -> 'a -> unitval poison_at : 'a t -> exn -> Stdlib.Printexc.raw_backtrace -> unitpoison_at stream exn bt marks the stream as poisoned at the current position, which means that subsequent attempts to push to the stream will raise the given exception with backtrace.
ℹ️ This operation is not cancelable.
val poison : ?callstack:int -> 'a t -> exn -> unitpoison stream exn is equivalent to poison_at stream exn (Printexc.get_callstack n) where n defaults to 0.
peek_opt cursor immediately returns Some (value, next) with the value pushed to the position and a cursor to the next position, when the cursor points to a past position in the stream. Otherwise returns None or raises the exception that the stream was poisoned with.
read cursor immediately returns (value, next) with the value pushed to the position and a cursor to the next position, when the cursor points to a past position in the stream. If the cursor points to the current position of the stream, read cursor waits until a value is pushed to the stream or the stream is poisoned, in which case the exception that the stream was poisoned with will be raised.
val read_evt : 'a cursor -> ('a * 'a cursor) Picos_std_event.Event.tread_evt cursor returns an event that reads from the cursor position.