6 releases
0.1.5 | Nov 24, 2024 |
---|---|
0.1.4 | Nov 24, 2024 |
#608 in Rust patterns
319 downloads per month
5KB
parenv
Environment variable parser with a clap style derive macro and elm style error reporting.
Installation
cargo add parenv
Usage
Here are some important features you should know about.
parenv
relies on theFromStr
trait to parse environment variables into the specified type.- The documentation comment on each field is used as the description for the corresponding environment variable.
- To make a field optional, wrap the type with an
Option
. - To set a prefix value, set the attribute
#[parenv(prefix = "ENV_")]
on your struct. - To set a suffix value, set the attribute
#[parenv(suffix = "_ARG")]
on your struct.
use std::{net::SocketAddr, path::PathBuf};
use parenv::Environment;
#[derive(Debug, Environment)]
#[parenv(prefix = "ENV_", suffix = "_ARG")]
struct Env {
/// The cat
cat: Option<u8>,
/// The dog
dog: SocketAddr,
/// The file
file: PathBuf,
}
fn main() {
let env = Env::parse();
dbg!(env.cat, env.dog, env.file);
}
Demo
Dependencies
~4–10MB
~110K SLoC