Crates.io | concat-with |
lib.rs | concat-with |
version | 0.2.9 |
source | src |
created_at | 2020-06-02 18:45:22.641021 |
updated_at | 2023-11-30 03:29:39.745883 |
description | Extend the function of the `concat!` macro in `std`. |
homepage | https://magiclen.org/concat-with |
repository | https://github.com/magiclen/concat-with |
max_upload_size | |
id | 249362 |
size | 14,167 |
While the concat!
macro in std
is useful to create a static string slice (&'static str
) from literals, it cannot set a separator for those. This crate therefore provides another concat!
macro to deal with that situation.
assert_eq!("test10btrue", concat_with::concat!("test", 10, 'b', true));
assert_eq!("test, 10, b, true", concat_with::concat!(with ", ", "test", 10, 'b', true));
assert_eq!("test\n10\nb\ntrue", concat_with::concat_line!("test", 10, 'b', true));
Prefixes and suffixes can also be added.
assert_eq!("Someone says: Hello.\nSomeone says: Nice to meet you!", concat_with::concat_line!(prefix "Someone says: ", "Hello.", "Nice to meet you!"));
The concat_impl!
macro can be used to create your own macros like concat_line!
which concatenates literals separated by a specific literal.
#[doc(hidden)]
pub use concat_with::{concat, concat_impl}; // re-export `concat!` and `concat_impl!` if your custom macros use `#[macro_export]`
concat_impl! {
#[macro_export]
/// Concatenates literals into a static string slice separated by a comma and a whitespace, `, `. Prefixes and suffixes can also be added.
concat_with_comma => ", ",
#[macro_export]
/// Concatenates literals into a static string slice separated by a colon, `:`. Prefixes and suffixes can also be added.
concat_with_colon => ':',
}
assert_eq!("test, 10, b, true", concat_with_comma!("test", 10, 'b', true));
assert_eq!("test:10:b:true", concat_with_colon!("test", 10, 'b', true));
https://crates.io/crates/concat-with