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

#720 in Text processing

Download history 29021/week @ 2025-03-28 27723/week @ 2025-04-04 29438/week @ 2025-04-11 22812/week @ 2025-04-18 30184/week @ 2025-04-25 31619/week @ 2025-05-02 28025/week @ 2025-05-09 20676/week @ 2025-05-16 27976/week @ 2025-05-23 30185/week @ 2025-05-30 26695/week @ 2025-06-06 25835/week @ 2025-06-13 21394/week @ 2025-06-20 18066/week @ 2025-06-27 18398/week @ 2025-07-04 19978/week @ 2025-07-11

81,186 downloads per month
Used in 64 crates (8 directly)

Zlib OR Apache-2.0 OR MIT

7KB
78 lines

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);
}

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

utf16_lit

Provides a macro_rules to re-encode utf8 to utf16.

No runtime deps