PickleDB

Build Status Crate API

PickleDB is a lightweight and simple key-value store written in Rust, heavily inspired by Python's PickleDB

PickleDB is fun and easy to use

```rust use pickledb::{PickleDb, PickleDbDumpPolicy, SerializationMethod};

fn main() {

// create a new DB with AutoDump (meaning every change is written to the file)
// and with Json serialization (meaning DB will be dumped to file as a Json object)
let mut db = PickleDb::new("example.db", PickleDbDumpPolicy::AutoDump, SerializationMethod::Json);

// set the value 100 to the key 'key1'
db.set("key1", &100).unwrap();

// print the value of key1
println!("The value of key1 is: {}", db.get::<i32>("key1").unwrap());

// load the DB from the same file
let db2 = PickleDb::load("example.db", PickleDbDumpPolicy::DumpUponRequest, SerializationMethod::Json).unwrap();

// print the value of key1
println!("The value of key1 as loaded from file is: {}", db2.get::<i32>("key1").unwrap());

} ```

Installation

This crate works with Cargo and can be found in crates.io Add this to your Cargo.toml:

toml [dependencies] pickledb = "0.3.0"

Documentation

All documentation for this crate can be found in docs.rs

Examples

There are currently two examples shipped with PickleDB:

Changelog

Version 0.3.0

Version 0.2.0