Expand description
This crate provides compile-time defined format strings support for
std::fmt
macros.
§Example
use reusable_fmt::*;
// This defines your format strings
fmt_reuse! {
TEST1 = "This is a test! {}";
TEST2 = "You can pass multiple format args! {} {}";
TEST3 = r#"Raw Strings work too!! {}"#;
TEST4 = "Named args {arg}";
TEST5 = "Positional args {1} {0}";
TEST6 = "Mixed {} {2} {1} {arg}";
}
fn main() {
prntln!(TEST1, "Hello World"); // This is a test! Hello World
let test = fmt!(TEST6, "Hello", "Test", "World", arg="Named"); // Mixed Hello World Test Named
prntln!("{}", "WOW This works too!");
}
§Syntax
Format strings are explicitly defined using the fmt_reuse!
macro first
All format related macros follow a syntax similar to std::fmt
macros (and even support the
same syntax as them!)
The general syntax is:
fmt!(<KEY>, <ARGUMENTS>)
wrt!(<BUFFER>, <KEY>, <ARGUMENTS>)