pub struct NodeStream<TMuxer, TUserData>where
    TMuxer: StreamMuxer,
{ /* private fields */ }
Expand description

Implementation of Stream that handles a node.

The stream will receive substreams and can be used to open new outgoing substreams. Destroying the NodeStream will not close the existing substreams.

The stream will close once both the inbound and outbound channels are closed, and no more outbound substream attempt is pending.

Implementations

Creates a new node events stream.

Starts the process of opening a new outbound substream.

Returns an error if the outbound side of the muxer is closed.

After calling this method, polling the stream should eventually produce either an OutboundSubstream event or an OutboundClosed event containing the user data that has been passed to this method.

Returns true if the inbound channel of the muxer is open.

If true is returned, more inbound substream will be produced.

Returns true if the outbound channel of the muxer is open.

If true is returned, more outbound substream can be opened. Otherwise, calling open_substream will return an Err.

Destroys the node stream and returns all the pending outbound substreams.

Destroys all outbound streams and returns the corresponding user data.

Trigger node shutdown.

After this, NodeStream::poll will eventually produce None, when both endpoints are closed.

Trait Implementations

Formats the value using the given formatter. Read more
Executes the destructor for this type. Read more
The type of item this stream will yield on success.
The type of error this stream may generate.
Attempt to pull out the next value of this stream, returning None if the stream is finished. Read more
Creates an iterator which blocks the current thread until each item of this stream is resolved. Read more
Converts this stream into a Future. Read more
Converts a stream of type T to a stream of type U. Read more
Converts a stream of error type T to a stream of error type U. Read more
Filters the values produced by this stream according to the provided predicate. Read more
Filters the values produced by this stream while simultaneously mapping them to a different type. Read more
Chain on a computation for when a value is ready, passing the resulting item to the provided closure f. Read more
Chain on a computation for when a value is ready, passing the successful results to the provided closure f. Read more
Chain on a computation for when an error happens, passing the erroneous result to the provided closure f. Read more
Collect all of the values of this stream into a vector, returning a future representing the result of that computation. Read more
Execute an accumulating computation over a stream, collecting all the values into one final result. Read more
Skip elements on this stream while the predicate provided resolves to true. Read more
Take elements from this stream while the predicate provided resolves to true. Read more
Runs this stream to completion, executing the provided closure for each element on the stream. Read more
Map this stream’s error to any error implementing From for this stream’s Error, returning a new stream. Read more
Creates a new stream of at most amt items of the underlying stream. Read more
Creates a new stream which skips amt items of the underlying stream. Read more
Fuse a stream such that poll will never again be called once it has finished. Read more
Borrows a stream, rather than consuming it. Read more
👎Deprecated: functionality provided by select now
An adapter for merging the output of two streams. Read more
An adapter for zipping two streams together. Read more
Adapter for chaining two stream. Read more
Creates a new stream which exposes a peek method. Read more
An adaptor for chunking up items of the stream inside a vector. Read more
Creates a stream that selects the next element from either this stream or the provided one, whichever is ready first. Read more
A future that completes after the given stream has been fully processed into the sink, including flushing. Read more
Do something with each item of this stream, afterwards passing it on. Read more
Do something with the error of this stream, afterwards passing it on. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Should always be Self
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.