Add a demo of the timeout
method
This commit is contained in:
parent
bd4528edf0
commit
0706bae9f7
1 changed files with 18 additions and 8 deletions
|
@ -1,22 +1,32 @@
|
||||||
|
use std::{pin::pin, time::Duration};
|
||||||
use trpl::{ReceiverStream, Stream, StreamExt};
|
use trpl::{ReceiverStream, Stream, StreamExt};
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
trpl::run(async {
|
trpl::run(async {
|
||||||
let mut messages = get_messages();
|
let mut messages =
|
||||||
|
pin!(get_messages().timeout(Duration::from_millis(200)));
|
||||||
|
|
||||||
while let Some(message) = messages.next().await {
|
while let Some(result) = messages.next().await {
|
||||||
println!("{message}");
|
match result {
|
||||||
|
Ok(message) => println!("{message}"),
|
||||||
|
Err(reason) => eprintln!("Problem: {reason:?}"),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_messages() -> impl Stream<Item = String> {
|
fn get_messages() -> impl Stream<Item = String> {
|
||||||
let (tx, rx) = trpl::channel();
|
let (tx, rx) = trpl::channel();
|
||||||
|
|
||||||
let messages = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j"];
|
trpl::spawn_task(async move {
|
||||||
for message in messages {
|
let messages = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j"];
|
||||||
tx.send(format!("Message: '{message}'")).unwrap();
|
for (index, message) in messages.into_iter().enumerate() {
|
||||||
}
|
let time_to_sleep = if index % 2 == 0 { 100 } else { 300 };
|
||||||
|
trpl::sleep(Duration::from_millis(time_to_sleep)).await;
|
||||||
|
|
||||||
|
tx.send(format!("Message: '{message}'")).unwrap();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
ReceiverStream::new(rx)
|
ReceiverStream::new(rx)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue