#string-formatting #formatting #batch #substitution

expand_str

ExpandEnvironmentStrings-like function and string formatting utility

2 releases

0.1.1 Jun 18, 2020
0.1.0 Oct 15, 2019

#14 in #substitution

Download history 168/week @ 2024-11-29 134/week @ 2024-12-06 205/week @ 2024-12-13 24/week @ 2024-12-20 38/week @ 2024-12-27 55/week @ 2025-01-03 165/week @ 2025-01-10 90/week @ 2025-01-17 126/week @ 2025-01-24 197/week @ 2025-01-31 198/week @ 2025-02-07 273/week @ 2025-02-14 150/week @ 2025-02-21 158/week @ 2025-02-28 244/week @ 2025-03-07 227/week @ 2025-03-14

826 downloads per month
Used in path-cleaner

WTFPL license

11KB
206 lines

expand_str

ExpandEnvironmentStrings emulation with more strict input checking and a way to substitute your own variable values.

Example

Add expand_str to your dependencies of your Cargo.toml:

[dependencies]
expand_str = "0.1"

And then, in your rust file:


fn main() {
    println!("{}", expand_str::expand_string_with_env("This is what's in your PATH: %PATH%").unwrap());
}

If you only want string formatting, environment variable access code can be dropped, e.g.:

[dependencies.expand_str]
version = "0.1"
default-features = false

(Exact feature name is env, but there are no other features at the moment).

Formatting-only example:

fn main() {
    let values = {
        let mut values = HashMap::new();
        values.insert("DRINK", "cup of tea");
        values.insert("FOOD", "cookies");
        values
    };

    let src = "Here is a %DRINK% and some %FOOD%.";
    let x = expand_string_with_values(src, |id| values.get(id)).unwrap();
    println!("{}", x);
}

No runtime deps

Features