2
0
Fork 1
mirror of https://github.com/async-rs/async-std.git synced 2025-10-24 05:16:36 +00:00

feat: Add Stream::timeout

This commit is contained in:
k-nasa 2019-10-16 15:31:07 +09:00
parent f00d32ee7d
commit 7a87dea085

View file

@ -104,13 +104,16 @@ cfg_if! {
cfg_if! { cfg_if! {
if #[cfg(any(feature = "unstable", feature = "docs"))] { if #[cfg(any(feature = "unstable", feature = "docs"))] {
mod merge; mod merge;
mod timeout;
use std::pin::Pin; use std::pin::Pin;
use std::time::Duration;
use crate::future::Future; use crate::future::Future;
use crate::stream::FromStream; use crate::stream::FromStream;
pub use merge::Merge; pub use merge::Merge;
pub use timeout::TimeoutStream;
} }
} }
@ -1044,6 +1047,40 @@ extension_trait! {
Skip::new(self, n) Skip::new(self, n)
} }
#[doc=r#"
Await a stream or times out after a duration of time.
If you want to await an I/O future consider using
[`io::timeout`](../io/fn.timeout.html) instead.
# Examples
```
# fn main() -> std::io::Result<()> { async_std::task::block_on(async {
#
use std::time::Duration;
use async_std::stream;
use async_std::prelude::*;
let mut s = stream::repeat(1).take(3).timeout(Duration::from_secs(1));
while let Some(v) = s.next().await {
assert_eq!(v, Ok(1));
}
#
# Ok(()) }) }
```
"#]
#[cfg(any(feature = "unstable", feature = "docs"))]
#[cfg_attr(feature = "docs", doc(cfg(unstable)))]
fn timeout(self, dur: Duration) -> TimeoutStream<Self>
where
Self: Stream + Sized,
{
TimeoutStream::new(self, dur)
}
#[doc = r#" #[doc = r#"
A combinator that applies a function as long as it returns successfully, producing a single, final value. A combinator that applies a function as long as it returns successfully, producing a single, final value.
Immediately returns the error when the function returns unsuccessfully. Immediately returns the error when the function returns unsuccessfully.