#interval #tokio #stream #buffer #emit #regular #enums

tokio_interval_buffer

简单枚举包装器,实现了被包装对象的所有特性和特质

2个不稳定版本

0.2.0 2022年4月3日
0.1.0 2019年2月16日

#1605算法

MIT 许可证

10KB
92

提供了一种IntervalBuffer,可用于缓冲流并在固定时间间隔发射值。

当您接收到流式数据但希望批量解析时,这非常有用。

extern crate irc;
extern crate failure;
extern crate tokio_interval_buffer;
extern crate futures;
extern crate tokio;

use irc::client::prelude::*;
use tokio_interval_buffer::IntervalBuffer;

fn main() {
    tokio::run(futures::future::lazy(|| {
        let client = IrcClient::from_config(Config {
            nickname: Some(String::from("...")),
            server: Some(String::from("...")),
            channels: Some(vec![String::from("...")]),
            ..Default::default()
        })
        .expect("Could not create an irc client");

        // Take the IRC stream and process all the messages every 10 seconds
        let buffered_receiver = IntervalBuffer::<_, _, failure::Error>::new(
            client
                .stream()
                .map_err(|e| failure::format_err!("Client stream error: {:?}", e)),
            std::time::Duration::from_secs(10),
        );

        buffered_receiver
            .for_each(|b| {
                println!("Buffer: {:?}", b);
                Ok(())
            })
            .map_err(|e| {
                println!("Buffered receiver error: {:?}", e);
            })
    }));
}

依赖项

~2.6–4MB
~61K SLoC