rustc/vendor/unicode-normalization
2021-04-15 23:27:12 +01:00
..
benches New upstream version 1.46.0~beta.2+dfsg1 2020-08-06 23:19:31 +01:00
scripts New upstream version 1.52.0~beta.3+dfsg1 2021-04-15 23:27:12 +01:00
src New upstream version 1.52.0~beta.3+dfsg1 2021-04-15 23:27:12 +01:00
.cargo-checksum.json New upstream version 1.52.0~beta.3+dfsg1 2021-04-15 23:27:12 +01:00
Cargo.toml New upstream version 1.52.0~beta.3+dfsg1 2021-04-15 23:27:12 +01:00
COPYRIGHT New upstream version 1.32.0~beta.2+dfsg1 2018-12-16 10:13:16 -08:00
LICENSE-APACHE New upstream version 1.32.0~beta.2+dfsg1 2018-12-16 10:13:16 -08:00
LICENSE-MIT New upstream version 1.32.0~beta.2+dfsg1 2018-12-16 10:13:16 -08:00
README.md New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00

unicode-normalization

Build Status Docs

Unicode character composition and decomposition utilities as described in Unicode Standard Annex #15.

This crate requires Rust 1.36+.

extern crate unicode_normalization;

use unicode_normalization::char::compose;
use unicode_normalization::UnicodeNormalization;

fn main() {
    assert_eq!(compose('A','\u{30a}'), Some('Å'));

    let s = "ÅΩ";
    let c = s.nfc().collect::<String>();
    assert_eq!(c, "ÅΩ");
}

crates.io

You can use this package in your project by adding the following to your Cargo.toml:

[dependencies]
unicode-normalization = "0.1.16"

no_std + alloc support

This crate is completely no_std + alloc compatible. This can be enabled by disabling the std feature, i.e. specifying default-features = false for this crate on your Cargo.toml.