# wchar
[<img alt="build status" src="https://img.shields.io/github/workflow/status/Juici/wchar-rs/ci?style=for-the-badge" height="20">](https://github.com/Juici/wchar-rs/actions?query=branch%3Amaster)
[<img alt="crates.io" src="https://img.shields.io/crates/v/wchar?style=for-the-badge&logo=rust" height="20">](https://crates.io/crates/wchar)
[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-wchar-4d76ae?style=for-the-badge&logo=" height="20">](https://docs.rs/wchar)
This library introduces two macros to create UTF-16 and UTF-32 wide strings at
compiler time, like `L` string literals in C.
```toml
[dependencies]
wchar = "0.10"
```
*Compiler support: requires rustc 1.53+*
## Example
```rust
use wchar::{wch, wchz, wchar_t};
// Equivalent to `#define RUST L"Rust"` in C.
const RUST: &[wchar_t] = wch!("Rust\0"); // C strings are nul-terminated.
// Equivalent to `#define ALSO_RUST L"Rust"` in C.
const ALSO_RUST: &[wchar_t] = wchz!("Rust");
assert_eq!(RUST, &['R' as wchar_t, 'u' as wchar_t, 's' as wchar_t, 't' as wchar_t, 0x0000]);
assert_eq!(RUST, ALSO_RUST);
```
## License
This project is licensed under either of [Apache License, Version 2.0](LICENSE-APACHE)
or [MIT License](LICENSE-MIT) at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.