File: README.md

package info (click to toggle)
rust-unicode-normalization-alignments 0.1.12-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 628 kB
  • sloc: python: 340; makefile: 4
file content (44 lines) | stat: -rw-r--r-- 1,290 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# unicode-normalization-alignments

[![Build Status](https://travis-ci.org/n1t0/unicode-normalization.svg)](https://travis-ci.org/n1t0/unicode-normalization)
[![Docs](https://docs.rs/unicode-normalization-alignments/badge.svg)](https://docs.rs/unicode-normalization-alignments/)

This is a forked version of [unicode-normalization](https://github.com/unicode-rs/unicode-normalization)
wich provides alignment information during normalization.

Unicode character composition and decomposition utilities as described in
[Unicode Standard Annex #15](http://www.unicode.org/reports/tr15/).

This crate requires Rust 1.36+.

```rust
extern crate unicode_normalization_alignments;

use unicode_normalization_alignments::char::compose;
use unicode_normalization_alignments::UnicodeNormalization;

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

	let s = "ÅΩ";
	let c = s.nfc().map(|(c, diff)| {
		match diff {
			0 => println!("Nothing changed here"),
			1 => println!("New character"),
			_ => println!("{} characters were removed", diff),
		}

		c
	}).collect::<String>();
	assert_eq!(c, "ÅΩ");
}
```

## crates.io

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

```toml
[dependencies]
unicode-normalization-alignments = "0.1.12"
```