pub struct AsyncBincodeStream<S, R, W, D> { /* private fields */ }
Expand description

A wrapper around an asynchronous stream that receives and sends bincode-encoded values.

To use, provide a stream that implements both futures_io::AsyncRead and futures_io::AsyncWrite, and then use futures_sink::Sink to send values and futures_core::Stream to receive them.

Note that an AsyncBincodeStream must be of the type crate::AsyncDestination in order to be compatible with an AsyncBincodeReader on the remote end (recall that it requires the serialized size prefixed to the serialized data). The default is crate::SyncDestination, but these can be easily toggled between using AsyncBincodeStream::for_async.

Implementations

Gets a reference to the underlying stream.

It is inadvisable to directly read from or write to the underlying stream.

Gets a mutable reference to the underlying stream.

It is inadvisable to directly read from or write to the underlying stream.

Unwraps this AsyncBincodeStream, returning the underlying stream.

Note that any leftover serialized data that has not yet been sent, or received data that has not yet been deserialized, is lost.

Make this stream include the serialized data’s size before each serialized value.

This is necessary for compatability with a remote AsyncBincodeReader.

Make this stream only send bincode-encoded values.

This is necessary for compatability with stock bincode receivers.

Trait Implementations

Formats the value using the given formatter. Read more

Returns the “default value” for a type. Read more

Converts to this type from the input type.

The type of value produced by the sink when an error occurs.

Attempts to prepare the Sink to receive a value. Read more

Begin the process of sending a value to the sink. Each call to this function must be preceded by a successful call to poll_ready which returned Poll::Ready(Ok(())). Read more

Flush any remaining output from this sink. Read more

Flush any remaining output and close this sink, if necessary. Read more

Values yielded by the stream.

Attempt to pull out the next value of this stream, registering the current task for wakeup if the value is not yet available, and returning None if the stream is exhausted. Read more

Returns the bounds on the remaining length of the stream. 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

Converts to this type from the input type.

Returns the argument unchanged.

Calls U::from(self).

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

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.

The type of successful values yielded by this future

The type of failures yielded by this future

Poll this TryStream as if it were a Stream. Read more