#read-write #io-write #progress #io-read #callback #stream #read

progress-streams

Progress callbacks for types which implement Read/Write

2 stable releases

Uses old Rust 2015

1.1.0 Jul 25, 2019
1.0.0 Oct 10, 2018

#799 in Data structures

Download history 327/week @ 2024-07-21 315/week @ 2024-07-28 241/week @ 2024-08-04 389/week @ 2024-08-11 446/week @ 2024-08-18 401/week @ 2024-08-25 449/week @ 2024-09-01 671/week @ 2024-09-08 470/week @ 2024-09-15 542/week @ 2024-09-22 537/week @ 2024-09-29 545/week @ 2024-10-06 744/week @ 2024-10-13 665/week @ 2024-10-20 585/week @ 2024-10-27 738/week @ 2024-11-03

2,799 downloads per month
Used in 11 crates (6 directly)

MIT license

7KB

progress-streams

Rust crate to provide progress callbacks for types which implement io::Read or io::Write.

Examples

Reader

extern crate progress_streams;

use progress_streams::ProgressReader;
use std::fs::File;
use std::io::Read;
use std::sync::Arc;
use std::sync::atomic::{AtomicUsize, Ordering};
use std::thread;
use std::time::Duration;

fn main() {
    let total = Arc::new(AtomicUsize::new(0));
    let mut file = File::open("/dev/urandom").unwrap();
    let mut reader = ProgressReader::new(&mut file, |progress: usize| {
        total.fetch_add(progress, Ordering::SeqCst);
    });

    {
        let total = total.clone();
        thread::spawn(move || {
            loop {
                println!("Read {} KiB", total.load(Ordering::SeqCst) / 1024);
                thread::sleep(Duration::from_millis(16));
            }
        });
    }

    let mut buffer = [0u8; 8192];
    while total.load(Ordering::SeqCst) < 100 * 1024 * 1024 {
        reader.read(&mut buffer).unwrap();
    }
}

Writer

extern crate progress_streams;

use progress_streams::ProgressWriter;
use std::io::{Cursor, Write};
use std::sync::Arc;
use std::sync::atomic::{AtomicUsize, Ordering};
use std::thread;
use std::time::Duration;

fn main() {
    let total = Arc::new(AtomicUsize::new(0));
    let mut file = Cursor::new(Vec::new());
    let mut writer = ProgressWriter::new(&mut file, |progress: usize| {
        total.fetch_add(progress, Ordering::SeqCst);
    });

    {
        let total = total.clone();
        thread::spawn(move || {
            loop {
                println!("Written {} Kib", total.load(Ordering::SeqCst) / 1024);
                thread::sleep(Duration::from_millis(16));
            }
        });
    }

    let buffer = [0u8; 8192];
    while total.load(Ordering::SeqCst) < 1000 * 1024 * 1024 {
        writer.write(&buffer).unwrap();
    }
}

No runtime deps