Matthew Maurer | 19837bd | 2020-06-02 11:15:36 -0700 | [diff] [blame] | 1 | # unicode-width |
| 2 | |
| 3 | Determine displayed width of `char` and `str` types according to |
| 4 | [Unicode Standard Annex #11][UAX11] rules. |
| 5 | |
| 6 | [UAX11]: http://www.unicode.org/reports/tr11/ |
| 7 | |
| 8 | [](https://travis-ci.org/unicode-rs/unicode-width) |
| 9 | |
| 10 | [Documentation](https://unicode-rs.github.io/unicode-width/unicode_width/index.html) |
| 11 | |
| 12 | ```rust |
| 13 | extern crate unicode_width; |
| 14 | |
| 15 | use unicode_width::UnicodeWidthStr; |
| 16 | |
| 17 | fn main() { |
| 18 | let teststr = "Hello, world!"; |
| 19 | let width = UnicodeWidthStr::width(teststr); |
| 20 | println!("{}", teststr); |
| 21 | println!("The above string is {} columns wide.", width); |
| 22 | let width = teststr.width_cjk(); |
| 23 | println!("The above string is {} columns wide (CJK).", width); |
| 24 | } |
| 25 | ``` |
| 26 | |
| 27 | **NOTE:** The computed width values may not match the actual rendered column |
| 28 | width. For example, the woman scientist emoji comprises of a woman emoji, a |
| 29 | zero-width joiner and a microscope emoji. |
| 30 | |
| 31 | ```rust |
| 32 | extern crate unicode_width; |
| 33 | use unicode_width::UnicodeWidthStr; |
| 34 | |
| 35 | fn main() { |
| 36 | assert_eq!(UnicodeWidthStr::width("👩"), 2); // Woman |
| 37 | assert_eq!(UnicodeWidthStr::width("🔬"), 2); // Microscope |
| 38 | assert_eq!(UnicodeWidthStr::width("👩🔬"), 4); // Woman scientist |
| 39 | } |
| 40 | ``` |
| 41 | |
| 42 | See [Unicode Standard Annex #11][UAX11] for precise details on what is and isn't |
| 43 | covered by this crate. |
| 44 | |
| 45 | ## features |
| 46 | |
| 47 | unicode-width does not depend on libstd, so it can be used in crates |
| 48 | with the `#![no_std]` attribute. |
| 49 | |
| 50 | ## crates.io |
| 51 | |
| 52 | You can use this package in your project by adding the following |
| 53 | to your `Cargo.toml`: |
| 54 | |
| 55 | ```toml |
| 56 | [dependencies] |
| 57 | unicode-width = "0.1.7" |
| 58 | ``` |