Crate config_file2

Source
Expand description

§config-file2

Extremely easy to load and store your configuration file!

§Usage

  1. Add dependency:
    cargo add config-file2
  2. Enable which format you want to use in features.
    • all
    • toml (enabled by default)
    • json
    • xml
    • yaml
    • ron

Here’s an example of how to use it with json and yaml format:

[dependencies]
config-file2 = { version = "0.4", features = ["json", "yaml"] }

§Examples

use config_file2::{LoadConfigFile, StoreConfigFile};
use serde::{Serialize, Deserialize};

#[derive(Serialize, Deserialize)]
struct Config {
    host: String,
}

// store
Config { host: "example.com".into() }.store("/tmp/myconfig.toml").unwrap();

// load
let config = Config::load("/tmp/myconfig.toml").unwrap().unwrap();
assert_eq!(config.host.as_str(), "example.com");

Another way to store a struct into a configuration file:

use config_file2::Storable;
use serde::{Serialize, Deserialize};
use std::path::{Path, PathBuf};

#[derive(Serialize)]
struct TestStorable {
    path: PathBuf,
}

impl Storable for TestStorable {
    fn path(&self) -> impl AsRef<Path> {
        &self.path
    }
}

TestStorable { path: PathBuf::from("/tmp/myconfig.toml") }.store().unwrap();

§more

fn load_with_specific_format(path: impl AsRef<Path>, config_type: ConfigFormat) -> Result<Self>;
fn load_or_default(path: impl AsRef<Path>) -> Result<Self>;
fn store_with_specific_format(self, path: impl AsRef<Path>, config_type: ConfigFormat) -> Result<()>;
fn store_without_overwrite(self, path: impl AsRef<Path>) -> Result<()>;

Re-exports§

pub use error::Result;

Modules§

error

Enums§

ConfigFormat
Format of configuration file.

Traits§

LoadConfigFile
Trait for loading a struct from a configuration file. This trait is automatically implemented when serde::Deserialize is.
Storable
A more easy way to store a struct into a configuration file.
StoreConfigFile
Trait for storing a struct into a configuration file. This trait is automatically implemented when serde::Serialize is.