4 releases (stable)
Uses new Rust 2024
| 2.0.0 | Jan 28, 2026 |
|---|---|
| 1.0.1 | Jul 21, 2019 |
| 1.0.0 | Jul 19, 2019 |
| 0.1.0 | Jul 19, 2019 |
#173 in Parser implementations
560,388 downloads per month
Used in 254 crates
(10 directly)
15KB
221 lines
UTF-8 decode
This crates provides incremental UTF-8 decoders implementing the
Iterator trait, wrapping around u8 bytes iterators.
It also provide the const-compatible try_decode_char to decode UTF-8
byte streams, even in const contexts.
Decoder
The Decoder iterator can be used, for instance, to decode u8 slices.
use utf8_decode::Decoder;
let bytes = [72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100, 33];
let decoder = Decoder::new(bytes.iter().cloned());
let mut string = String::new();
for c in decoder {
string.push(c?);
}
println!("{}", string);
TryDecoder
The TryDecoder iterator can be used, for instance, to decode UTF-8
encoded files.
use utf8_decode::TryDecoder;
let file = File::open("examples/file.txt")?;
let decoder = TryDecoder::new(file.bytes());
let mut string = String::new();
for c in decoder {
string.push(c?);
}
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.