#format-string #string #fmt #format #macro

no-std reusable-fmt

Reusable format strings for format! and friends

4 releases

0.2.0 May 14, 2021
0.1.2 Apr 4, 2021
0.1.1 Apr 4, 2021
0.1.0 Apr 4, 2021

#43 in #fmt

Download history 68/week @ 2024-07-25 64/week @ 2024-08-01 37/week @ 2024-08-08 117/week @ 2024-08-15 80/week @ 2024-08-22 55/week @ 2024-08-29 93/week @ 2024-09-05 47/week @ 2024-09-12 101/week @ 2024-09-19 113/week @ 2024-09-26 141/week @ 2024-10-03 275/week @ 2024-10-10 97/week @ 2024-10-17 253/week @ 2024-10-24 183/week @ 2024-10-31 187/week @ 2024-11-07

779 downloads per month

WTFPL license

9KB
93 lines

reusable-fmt

RUST crates.io docs.rs

Reusable format strings for std::fmt macros

Initial Release

This crate provides compile-time defined format string support for std::fmt macros like write!, print!, format!, etc.

Installation

Cargo.toml:

[dependencies]
reusable-fmt = { git = https://github.com/rupansh/reusable-fmt }

src.rs:

use reusable_fmt::*;

Example Usage

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!");
}

Why

  • Makes format strings less redundant
  • No runtime overhead! everything is compile time.
  • Dependency-free (unless you count build-dependencies)

Contribution

Feel free to request and implement features. I am not that good with macros so code improvements are welcome too!

Testing

Tests should be run on nightly

cargo +nightly test

Documentation

Documentation should be compiled on nightly

cargo +nightly doc

No runtime deps

~190KB