# constcat
[data:image/s3,"s3://crabby-images/62cd7/62cd73d53f6bed255ecc421182a5c1f7718699e1" alt="Crates.io Version"](https://crates.io/crates/constcat)
[data:image/s3,"s3://crabby-images/79306/79306e651dde818ed3e0412bd57ba8acda46f12f" alt="Docs.rs Latest"](https://docs.rs/constcat)
[data:image/s3,"s3://crabby-images/ffa7a/ffa7a292a46664b5e63f19ff5bfdac2eb125769b" alt="Build Status"](https://github.com/rossmacarthur/constcat/actions/workflows/build.yaml?query=branch%3Atrunk)
[`std::concat!`] with support for `const` variables and expressions.
[`std::concat!`]: core::concat
Works on stable Rust ✨.
## 🚀 Getting started
Add `constcat` to your Cargo manifest.
```sh
cargo add constcat
```
Import the macro using the following.
```rust
use constcat::concat;
```
## 🤸 Usage
`concat!` works exactly like [`std::concat!`] except you can
now pass variables and constant expressions. For example:
```rust
const CRATE_NAME: &str = env!("CARGO_PKG_NAME");
const CRATE_VERSION: &str = env!("CARGO_PKG_VERSION");
const fn tada() -> &'static str { "🎉" }
const VERSION: &str = concat!(CRATE_NAME, " ", CRATE_VERSION, tada());
```
`concat_bytes!` works similarly except it yields a static byte slice. For
example:
```rust
const VERSION: u32 = 1;
const fn entries() -> &'static [u8] { b"example" }
const HEADER: &[u8] = concat_bytes!(&VERSION.to_le_bytes(), entries());
```
[`std::concat!`]: core::concat
## License
This project is distributed under the terms of both the MIT license and the Apache License (Version 2.0).
See [LICENSE-APACHE](LICENSE-APACHE) and [LICENSE-MIT](LICENSE-MIT) for details.