UTF-8 and UTF-16 character types, iterators and related methods for char
, u8
and u16
.
Utf8Char
: Achar
stored as UTF-8. Can be borrowed as astr
oru8
slice.Utf16Char
: Achar
stored as UTF-16. Can be borrowed as anu16
slice.- Conversion methods on
char
:- to and from UTF-8 as
[u8; 4]
or slice. - to and from UTF-16 as
(u16, Option<u16>)
or slice.
- to and from UTF-8 as
- Iterator adapters
for converting betwenn
u8
s andUtf8Char
s oru16
s andUtf16Char
s. - Optimized slice-based decoding iterators.
- Precise errors when decoding a char from UTF-8, UTF-16 or
u32
fails. - Utility methods on
u8
andu16
.
The minimum supported Rust version for 1.0.* releases is 1.56.
Later 1.y.0 releases might require newer Rust versions, but the three most
recent stable releases at the time of publishing will always be supported.
For example this means that if the current stable Rust version is 1.66 when
encode_unicode 1.1.0 is released, then encode_unicode 1.1.* will
not require a newer Rust version than 1.63.
#![no_std]
-mode: There are a few differences:Error
doesn't exist, butdescription()
is made available as an inherent impl.Extend
/FromIterator
-implementations forString
/Vec<u8>
/Vec<u16>
are missing.- There is no
io
, soUtf8Iterator
andUtf8CharSplitter
doesn't implementRead
. This feature is enabled by settingdefault-features=false
inCargo.toml
:encode_unicode = {version="0.3.4", default-features=false}
.
- Integration with the ascii crate:
Convert
Utf8Char
andUtf16Char
to and from ascii::AsciiChar
.
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.
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.
do.sh
can be used to check all feature combinations, test everything, show output from benchmarks in case setup fails, run fuzz tests for a while and lint everything (except fuzz tests).
It assumes rustup is installed and that cargo +release
works.
(It is named the way it is to autocomplete fully from the first character after ./
.)
The original purpose of this crate was to provide standins for the then
unstable encode_utf8()
and encode_utf16()
methods on char
.
The standins were removed in version 0.3 when Rust 1.15 stabilized the
encode_
methods, but the other stuff I added, such as iterators like
those encode_utf{8,16}()
returned for a while, might still be of use.