https://github.com/bells307/throttled-stream
Библиотека представляет расширения для Stream с задержкой возврата значения, а также ограничения количества элементов
https://github.com/bells307/throttled-stream
async rust stream
Last synced: 2 months ago
JSON representation
Библиотека представляет расширения для Stream с задержкой возврата значения, а также ограничения количества элементов
- Host: GitHub
- URL: https://github.com/bells307/throttled-stream
- Owner: bells307
- Created: 2023-04-10T15:01:33.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2024-03-20T08:41:49.000Z (about 1 year ago)
- Last Synced: 2025-01-22T21:19:32.571Z (4 months ago)
- Topics: async, rust, stream
- Language: Rust
- Homepage:
- Size: 14.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# throttled-stream
Данная библиотека представляет расширения для `Stream` с задержкой возврата значения, а также ограничения количества элементов
```rust
pub trait ThrottledStreamExt {
/// Получить `Stream`, который отдаст максимально возможное количество элементов
fn max(self, count: usize) -> CountedStream;/// Ожидание (засыпание) промежутка времени `dur` между отда элементов `Stream`'а
fn sleep(self, dur: Duration) -> DelayedStream;/// Интервальное ожидание между отдачами элемента. Это значит, что элементы будут выдаваться
/// **не чаще**, чем указанный `Duration`.
fn tick(self, dur: Duration) -> DelayedStream;
}
```## Example
```rust
use throttled_stream::ThrottledStreamExt;
use futures::{stream, StreamExt};
use std::pin::pin;
use std::time::Duration;#[tokio::main]
async fn main() {
let stream = stream::iter(vec![1, 3, 2, 4, 5])
.tick(Duration::from_secs(1))
.max(4);let mut stream = pin!(stream);
let mut count = 0;
while let Some(v) = stream.next().await {
// elapsed 1 sec ...
println!("{}", v);
count += 1;
}assert_eq!(count, 4);
}
```