configparser Build Status

A simple configuration parsing utility with no dependencies built on Rust.

configparser works on a subset of ini configuration syntax.

Inspired by Python's configparser. This release is experimental, use at your own risk.

Installation

You can install this easily via cargo by including it in your Cargo.toml file like: yaml [dependencies] configparser = "0.1.1"

Usage

You can get a HashMap of type HashMap<String, HashMap<String, String>> with the Ini struct, like: ```rust use configparser::ini::Ini;

fn main() { let config = Ini::new(); match config.load("Path/to/file...") { Err(why) => panic!("{}", why), Ok() => () }; // You can then access the map normally like: let map = match config.getmap() { None => HashMap::new(), // or whatever you want to if the HashMap is empty Some(map) => map } for (key, value) in &map { println!("{:?}: {:?}", key, value); } // ...and do what you want with it. :) } `` TheIni` struct is the way to go forward and will soon have more features, such as reading from a string, insertion, deletion and variable access.

As of now, there's also a public function, to load an ini-syntax file and parse it into a hashmap. Support for this will be dropped in the near future, and will be changed into a macro when it's dropped. ```rust use configparser::ini;

fn main() { let map = ini::load("Path/to/file...");

// You can then access the map normally like: for (key, value) in &map { println!("{:?}: {:?}", key, value); } // ...and do what you want with it. :) } ```

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the LGPL-3.0 license, shall be dual licensed as above, without any additional terms or conditions.

Changelog

Future plans