## countio
[![Build Status][action-badge]][action-url]
[![Crate Docs][docs-badge]][docs-url]
[![Crate Version][crates-badge]][crates-url]
[![Crate Coverage][coverage-badge]][coverage-url]
**Also check out other `xwde` projects [here](https://github.com/xwde).**
[action-badge]: https://img.shields.io/github/actions/workflow/status/xwde/countio/ci.yaml?branch=main&label=build&logo=github&style=flat-square
[action-url]: https://github.com/xwde/countio/actions/workflows/ci.yaml
[crates-badge]: https://img.shields.io/crates/v/countio.svg?logo=rust&style=flat-square
[crates-url]: https://crates.io/crates/countio
[docs-badge]: https://img.shields.io/docsrs/countio?logo=Docs.rs&style=flat-square
[docs-url]: http://docs.rs/countio
[coverage-badge]: https://img.shields.io/codecov/c/github/xwde/countio?logo=codecov&logoColor=white&style=flat-square
[coverage-url]: https://app.codecov.io/gh/xwde/countio
The wrapper struct to enable byte counting for `std::io::Read`,
`std::io::Write`, `std::io::Seek` and its asynchronous variants from `futures`
and `tokio` crates.
### Features
- `std` to enable `std::io::{Read, Write, Seek}`. **Enabled by default**.
- `futures` to enable `futures_io::{AsyncRead, AsyncWrite, AsyncSeek}`.
- `tokio` to enable `tokio::io::{AsyncRead, AsyncWrite, AsyncSeek}`.
### Examples
- `std::io::Read`:
```rust
use std::io::{BufRead, BufReader};
use countio::Counter;
fn main() {
let reader = "Hello World!".as_bytes();
let reader = BufReader::new(reader);
let mut reader = Counter::new(reader);
let mut buf = String::new();
let len = reader.read_line(&mut buf).unwrap();
assert_eq!(len, reader.reader_bytes());
}
```
- `std::io::Write`:
```rust
use std::io::{BufWriter, Write};
use countio::Counter;
fn main() {
let writer = Vec::new();
let writer = BufWriter::new(writer);
let mut writer = Counter::new(writer);
let buf = "Hello World!".as_bytes();
let len = writer.write(buf).unwrap();
writer.flush().unwrap();
assert_eq!(len, writer.writer_bytes());
}
```
### Links
- [SOF3/count-write](https://crates.io/crates/count-write)