Figment is a semi-hierarchical configuration library for Rust so con-free, it's unreal.
use serde::Deserialize; use figment::{Figment, providers::{Format, Toml, Json, Env}}; #[derive(Deserialize)] struct Package { name: String, authors: Vec<String>, publish: Option<bool>, // ... and so on ... } #[derive(Deserialize)] struct Config { package: Package, rustc: Option<String>, // ... and so on ... } let config: Config = Figment::new() .merge(Toml::file("Cargo.toml")) .merge(Env::prefixed("CARGO_")) .merge(Env::raw().only(&["RUSTC", "RUSTDOC"])) .join(Json::file("Cargo.json")) .extract()?;See the documentation for a detailed usage guide and information.
Add the following to your Cargo.toml, enabling the desired built-in providers:
[dependencies] figment = { version = "0.10", features = ["toml"] }The following external libraries implement Figment providers:
-
Wraps existing providers. For any key ending in
_FILE(configurable), emits a key without the_FILEsuffix with a value corresponding to the contents of the file whose path is the original key's value.
Please submit a pull request to add your library to this list.
Figment is licensed under either of the following, at your option:
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT License (LICENSE-MIT or http://opensource.org/licenses/MIT)