Crates.io | slice |
lib.rs | slice |
version | 0.0.4 |
source | src |
created_at | 2017-04-27 15:45:02.302239 |
updated_at | 2018-08-07 09:42:45.693985 |
description | slices for streams implementing `std::io::read` and `std::io::write`. |
homepage | https://code.hinaria.com/p/slice |
repository | https://github.com/hinaria/slice |
max_upload_size | |
id | 12220 |
size | 10,948 |
create slices of io objects std::io::Read
and std::io::Write
.
if you have a file (or any other object), you can create a slice (or view) into some subset of it.
IoSlice
impls both std::io::Read
and std::io::Write
when the source implements them (and only one if the source
only implements one).
use { std::fs::File, slice::IoSlice };
let source = File::open("/home/annie/data.png")?;
let start = 10;
let length = 1000;
// create a slice into `home/annie/data.png`, consisting of bytes [10 .. 10 + 1000]
// of that file.
//
// `slice` impls both `std::io::Read` and `std::io::Write` because `source`
// does too.
let slice = IoSlice::new(source, start, length);
// use like any other `std::io::Read` or `std::io::Write`:
//
// slice.read_to_string(...)?;
// slice.read_exact(...)?;
// slice.write_all(...)?;
//
// writeln!(slice, "hello {}", name)?;
//