1 unstable release
0.1.0 | Nov 11, 2023 |
---|
#661 in Configuration
5KB
Carpenter
Create multiple config files easily.
Support
- Support for all Sized integers
- Support for Strings
- Lightweight
- Saves as binary for small file size
Installation/Usage
Installation
To use this crate you need these dependencies:
[dependencies]
bytestream = "0.4.1"
carpenter = "0.1.0"
Usage
use carpenter::ConfigManager;
// Create a struct and derive it with ConfigManager
#[derive(ConfigManager, PartialEq, Debug)]
struct Config {
_a: i32,
_b: bool,
_c: String,
}
fn main() {
// Create config builder
let config_factory = Config::init_config(
"meloencoding", // username
"config-rs-test", // application name
"test.bin" // config file name
);
// Lin: /home/alice/.config/{application name}/{config file name}
// Win: C:\Users\Alice\AppData\Roaming\{username}\{application name}\config/{config file name}
// Mac: /Users/Alice/Library/Application Support/com.{username}.{application name}
/{config file name}
// To save your config
let sample_config = Config {
_a: 400,
_b: true,
_c: String::from("Hey"),
};
config_factory.save(&sample_config);
// To read the saved config
assert_eq!(sample_config, config_factory.read());
}
Config file
- Byte order is Big endian.
- i32 = 4 bytes so 0x00-0x03 is 0x00_00_01_90 which is 400 in decimal.
- bool = 1 byte so 0x04-0x04 is 0x01 which is true in rust.
- String = is in this case 4 bytes so 0x05-0x08 is 0x48_65_79_00 which is "Hey\0". String gets null terminated.
Dependencies
~0.4–11MB
~64K SLoC