Expand description
Due to the Stream trait’s inclusion in std landing later than Tokio’s 1.0
release, most of the Tokio stream utilities have been moved into the tokio-stream
crate.
Why was Stream not included in Tokio 1.0?
Originally, we had planned to ship Tokio 1.0 with a stable Stream type
but unfortunately the RFC had not been merged in time for Stream to
reach std on a stable compiler in time for the 1.0 release of Tokio. For
this reason, the team has decided to move all Stream based utilities to
the tokio-stream crate. While this is not ideal, once Stream has made
it into the standard library and the MSRV period has passed, we will implement
stream for our different types.
While this may seem unfortunate, not all is lost as you can get much of the
Stream support with async/await and while let loops. It is also possible
to create a impl Stream from async fn using the async-stream crate.
Example
Convert a sync::mpsc::Receiver to an impl Stream.
use tokio::sync::mpsc;
let (tx, mut rx) = mpsc::channel::<usize>(16);
let stream = async_stream::stream! {
    while let Some(item) = rx.recv().await {
        yield item;
    }
};