2 unstable releases
0.2.2 | Dec 25, 2024 |
---|---|
0.1.0 | Nov 11, 2024 |
#1834 in Procedural macros
227 downloads per month
Used in realme
11KB
144 lines
Realme Macros
Macros for Realme.
Realme is a flexible and extensible configuration management library for Rust. It simplifies the process of loading and managing configuration settings from various sources. The name "Realme" is a play on "Realm" and "me," emphasizing its role in managing your application's configuration realm.
Features
- Support for multiple configuration formats for file(etc. TOML, JSON ...) or string or env or even command line flags, and you can easily add support for more formats
- Loosely typed — Serialization and deserialization of configuration data, configuration values may be read in any supported type, as long as there exists a reasonable conversion
- Custom parser support and flexible adaptor system for different data sources, for example, you can check the cmd parser, which allows you to read configuration from command line flags with clap
- Live watching and re-reading of config files
Installation
Add this to your Cargo.toml
:
[dependencies]
realme = {version = "0.1.4", features = ["toml"]}
You can also enable other features, for example, to use hot reloading feature, you need to enable json
andwatch
feature:
realme = {version = "0.1.4", features = ["toml", "json", "watch"]}
Usage
Here's a simple example of how to use Realme:
use realme::{Adaptor, Realme, StringSource, TomlParser};
use serde::{Serialize, Deserialize};
#[derive(Debug, Serialize, Deserialize)]
struct Person {
name: String,
age: u32,
birthday: chrono::DateTime<chrono::Utc>,
}
const CONFIGURATION1: &str = r#"
name = "John"
age = 30
birthday = 1993-01-01T00:00:00Z
"#;
fn main() {
let realme = Realme::builder()
.load(Adaptor::new(StringSource::<TomlParser>::new(
CONFIGURATION1,
)))
.build()
.expect("Building configuration object");
let person: Person = realme.try_deserialize().unwrap();
println!("{:?}", person);
println!("{:?}", realme);
assert_eq!(person.name, TryInto::<String>::try_into(realme.get("name").unwrap()).unwrap());
assert_eq!(person.age, realme.get_as::<u32, _>("age").unwrap());
assert_eq!(person.birthday, realme.get_as::<chrono::DateTime<chrono::Utc>, _>("birthday").unwrap());
}
For more detailed examples, check the examples
directory.
For a real-world example, you can check the Rinkle project.
Compartion
I am impressed by the following libraries:
And compared to them, Realme has the following features:
- Realme value conversion is all based on
serde
, so you can convert to any type that implementsserde::Serialize
andserde::Deserialize
trait - Realme has a flexible adaptor system, you can easily add your own adaptor by implementing the
Parser
andSource
trait - Realme supports file source hot reloading, you can reload the configuration file at runtime
But Realme has the following drawbacks:
- Newer project, less documentations, less tests
- It might have some breaking changes
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
Licensed under either of Apache License, Version 2.0 or MIT license at your option.Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~220–660KB
~16K SLoC