⚙ Very simple config parsing lib for rust!
I made this because I just needed a simple config parser for one of my projects and wanted to learn how to make a rust crate. Hopefully you will find it useful as well. :P
Just add the following to your Cargo.toml
:
toml
[dependencies]
simple_config_parser = "1.0.0"
This config parser is made for use with a simplified version of an ini file. There are no sections and currently no Escape character support. ```ini ; This is a comment
hello = World rust = Is great test = "TEST" ```
There are already a few config parsers out there for rust so why use this one?
There are a few reasons: - It's super simple to use - Its faster then some other popular config parsers (by only a few hundred Nano seconds but still) - It's code is easy to understand (For me at least) - It would make me happy (:P)
Create a new config from text and a file. ```rust // Import Lib use simpleconfigparser::Config;
// Create a new config and parse text let cfg = Config::new() .text("hello = world") .unwrap();
// Create a new config from a file let cfg2 = Config::new() .file("config.cfg") .unwrap(); ```
Get a value from a config. ```rust // Import Lib use simpleconfigparser::Config;
// Create a new config with no file let cfg = Config::new() .text("hello = World\nrust = Is great") .unwrap();
// Get a value from the config (As a string) println!("Hello, {}", cfg.get_str("hello").unwrap()); ```
Get value from a config as any type that implements FromStr. ```rust // Import Lib use simpleconfigparser::Config;
// Create a new config with no file let mut cfg = Config::new() .text("hello = true\nrust = 15\npi = 3.1415926535") .unwrap();
// Get a value from the config as bool
assert_eq!(cfg.get::
// Get a value from the config as int
assert_eq!(cfg.get::
// Get a value from the config as float
assert_eq!(cfg.get::