concat-reader 0.1.0

Adapter for reading through multiple reader continuously
Documentation
  • Coverage
  • 80%
    12 out of 15 items documented10 out of 12 items with examples
  • Size
  • Source code size: 35.39 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 2.58 MB This is the summed size of all files generated by rustdoc for all configured targets
  • Links
  • Larusso/concat-reader
    2 0 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • Larusso

concat-reader

Adapter for reading through multiple reader continuously

Build Status Crates.io

concat-reader is a library for Rust that contains utility functions and traits to create concatenated Read objects from any thing that implements IntoIterator.

  use concat_reader::{FileConcatRead, concat_path};
  use std::io::{self, Read, BufRead, BufReader, Write};
  fn main() -> io::Result<()>{
      let files = vec!["/path/to/file_1", "/path/to/file_2", "/path/to/file_3"];
      let mut f = concat_path(files);
      let mut buffered = BufReader::new(f);
      let stdout = io::stdout();
      let mut handle = stdout.lock();
      loop {
          let mut line = String::new();
          let r = buffered.read_line(&mut line)?;
          if r == 0 {
              return Ok(())
          }
          let f = buffered.get_ref().file_path();
          eprintln!("read from {:?}", f);
          handle.write(line.as_bytes())?;
      }
  }

Documentation: https://docs.rs/concat-reader

license

Apache License 2.0