8 releases (5 stable)

2.0.2 Feb 14, 2021
2.0.1 Feb 7, 2021
1.0.1 Sep 13, 2020
1.0.0 Jul 16, 2020
0.0.3 Mar 6, 2020

#598 in Text processing

Download history 27213/week @ 2024-11-15 15646/week @ 2024-11-22 19570/week @ 2024-11-29 22042/week @ 2024-12-06 19291/week @ 2024-12-13 6993/week @ 2024-12-20 3250/week @ 2024-12-27 19600/week @ 2025-01-03 29196/week @ 2025-01-10 21309/week @ 2025-01-17 26482/week @ 2025-01-24 29219/week @ 2025-01-31 32163/week @ 2025-02-07 24319/week @ 2025-02-14 28486/week @ 2025-02-21 25512/week @ 2025-02-28

115,717 downloads per month
Used in 64 crates (8 directly)

Zlib OR Apache-2.0 OR MIT

7KB
78 lines

License:Zlib min-rust crates.io docs.rs

utf16_lit

Provides a macro_rules to re-encode utf8 to utf16.


lib.rs:

Provides a macro_rules for making utf-16 literals.

Outputs are arrays of the correct size. Prefix the macro with & to make slices.

use utf16_lit::{utf16, utf16_null};

const EXAMPLE: &[u16] = &utf16!("example");

const EXAMPLE_NULL: &[u16] = &utf16_null!("example");

fn main() {
  let v: Vec<u16> = "example".encode_utf16().collect();
  assert_eq!(v, EXAMPLE);

  let v: Vec<u16> = "example".encode_utf16().chain(Some(0)).collect();
  assert_eq!(v, EXAMPLE_NULL);
  let v: Vec<u16> = "example\0".encode_utf16().collect();
  assert_eq!(v, EXAMPLE_NULL);

  // You don't even need to assign the output to a const.
  assert_eq!(utf16!("This works")[0], 'T' as u8 as u16);
}

No runtime deps