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

#439 in Text processing

Download history 6841/week @ 2022-12-04 8054/week @ 2022-12-11 3916/week @ 2022-12-18 1961/week @ 2022-12-25 5050/week @ 2023-01-01 6861/week @ 2023-01-08 7854/week @ 2023-01-15 8691/week @ 2023-01-22 7745/week @ 2023-01-29 5988/week @ 2023-02-05 7784/week @ 2023-02-12 8736/week @ 2023-02-19 7028/week @ 2023-02-26 8166/week @ 2023-03-05 6242/week @ 2023-03-12 7392/week @ 2023-03-19

29,190 downloads per month
Used in 45 crates (3 directly)

Zlib OR Apache-2.0 OR MIT

6KB
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