Crates.io | rustbreak |
lib.rs | rustbreak |
version | 2.0.0 |
source | src |
created_at | 2016-10-15 20:38:54.951345 |
updated_at | 2020-07-31 10:05:17.592303 |
description | A modular and configurable database |
homepage | https://github.com/TheNeikos/rustbreak |
repository | https://github.com/TheNeikos/rustbreak |
max_upload_size | |
id | 6863 |
size | 149,395 |
Rustbreak is an Daybreak inspired self-contained file database. It is meant to be fast and simple to use. You add it to your application and it should just work for you. The only thing you will have to take care of is saving.
This library started out because of a need to be able to quickly write an application in rust that needed some persistence while still being able to write arbitrary data to it.
In Ruby there is Daybreak however for Rust there was no similar crate, until now!
Add this to your Cargo.toml
:
[dependencies.rustbreak]
version = "2"
features = ["ron_enc"] # You can also use "yaml_enc" or "bin_enc"
# Check the documentation to add your own!
extern crate rustbreak;
use std::collections::HashMap;
use rustbreak::{MemoryDatabase, deser::Ron};
fn main() -> rustbreak::Result<()> {
let db = MemoryDatabase::<HashMap<u32, String>, Ron>::memory(HashMap::new())?;
println!("Writing to Database");
db.write(|db| {
db.insert(0, String::from("world"));
db.insert(1, String::from("bar"));
});
db.read(|db| {
// db.insert("foo".into(), String::from("bar"));
// The above line will not compile since we are only reading
println!("Hello: {:?}", db.get(&0));
})?;
Ok(())
}
Usage is quite simple:
FileDatabase
with FileDatabase::from_path
.MemoryDatabase
with MemoryDatabase::memory
.MmapDatabase
with MmapDatabase::mmap
or MmapDatabase::mmap_with_size
with mmap
feature.Database
with Database::from_parts
.Write
/Read
data from the Databasesave
periodically, or whenever it makes sense.
# use std::collections::HashMap;
use rustbreak::{MemoryDatabase, deser::Ron};
let db = MemoryDatabase::<HashMap<String, String>, Ron>::memory(HashMap::new(), Ron);
println!("Writing to Database");
db.write(|db| {
db.insert("hello".into(), String::from("world"));
db.insert("foo".into(), String::from("bar"));
});
db.read(|db| {
// db.insert("foo".into(), String::from("bar"));
// The above line will not compile since we are only reading
println!("Hello: {:?}", db.get("hello"));
});
The following parts explain how to enable the respective features. You can also enable several at the same time.
If you would like to use yaml you need to specify yaml_enc
as a feature:
[dependencies.rustbreak]
version = "1"
features = ["yaml_enc"]
You can now use rustbreak::deser::Yaml
as deserialization struct.
If you would like to use ron
you need to
specify ron_enc
as a feature:
[dependencies.rustbreak]
version = "1"
features = ["ron_enc"]
You can now use rustbreak::deser::Ron
as deserialization struct.
If you would like to use bincode you need to specify bin_enc
as a feature:
[dependencies.rustbreak]
version = "1"
features = ["bin_enc"]
You can now use rustbreak::deser::Bincode
as deserialization struct.