fast_config


github crates.io docs.rs
license code size issues GitHub Workflow Status

A small, safe, lightweight, and easy-to-use Rust crate to read and write to config files.

Currently only supports: JSON5, TOML, and YAML. But more formats (such as RON) are planned to be added later.

- click here to view code examples
- click here to jump to the Getting Started section


What is this crate?

fast_config was made to be a faster to set up, more light-weight, statically typed alternative to config. It also manages to have its own benefits compared to some other config-reading crates as there is full support for writing/saving config files, and it also provides you with some options regarding styling your config files


Why this crate?

Why not this crate?

⚠ Documentation and tests are still being made! ⚠

This crate has now entered the 'stable' stage, i however haven't battle-tested this in any big projects, so while there will NOT be any panics or crashes, some user-side error handling in particular might be a bit bugged

Documentation might be a little weird or incomplete at the current moment, too.

Feel free to contribute any fixes or open up an issue if you find anything that isn't working as it should!


Examples:

```rust,ignore use fast_config::Config; use serde::{Serialize, Deserialize};

// Creating a config struct to store our data

[derive(Serialize, Deserialize)]

pub struct MyData { pub student_debt: i32 }

fn main() { // Initializing a logging system (needed to show some warnings/errors) env_logger::init();

// Creating our data (default values)
let data = MyData {
    student_debt: 20
};

// Creating a new config struct with our data struct
let mut config = Config::new("./config/myconfig.json5", data).unwrap();

// Read/writing to the data
println!("I am ${} in debt", config.data.student_debt);
config.data.student_debt = i32::MAX;
println!("Oh no, i am now ${} in debt!!", config.data.student_debt);

// Saving it back to the disk
config.save().unwrap();

} ```

Getting started

1. Add the crate to your project via
cargo add fast_config

  1. Enable the feature(s) for the format(s) you'd like to use

    - Currently only json5, toml, and yaml are supported

4. Create a struct to hold your data that derives serde::Serialize and serde::Deserialize

  1. Create an instance of your data struct
  2. Optionally use the crate's Config type for convenience

    use fast_config::Config;

  3. Use
    rust,ignore let my_config = Config::new("./path/to/my_config_file", your_data).unwrap(); to create and store your config file(s)! Alternatively you could also use Config::from_settings to style some things and manually set the format!


View the examples directory for more advanced examples.