baildon

Crates.iobaildon
lib.rsbaildon
version0.1.2
sourcesrc
created_at2023-05-11 12:36:32.915813
updated_at2023-10-07 10:16:12.012759
descriptionB+Tree library
homepagehttps://github.com/garypen/baildon
repositoryhttps://github.com/garypen/baildon
max_upload_size
id862048
size736,116
Gary Pennington (garypen)

documentation

https://github.com/garypen/baildon#readme

README

baildon

A very simple B+Tree library.

Features:

  • Generic B+Tree
  • Asynchronous (uses tokio)
  • Write Ahead Log
  • serde based storage format (bincode)
use baildon::tree::Baildon;
use baildon::tree::Direction;

// Create a B+Tree with usize for key and value, branching factor 7
let tree = Baildon::<usize, usize>::try_new("retrieve_keys_from_empty_tree.db", 7)
    .await
    .expect("creates tree file");

// Collect all our keys
let keys = tree
    .keys(Direction::Ascending)
    .await
    .collect::<Vec<usize>>()
    .await;

// It should be empty, we didn't add any keys
assert!(keys.is_empty());

// Remove our B+Tree file, we aren't going to use it again
std::fs::remove_file("retrieve_keys_from_empty_tree.db").expect("cleanup");

Crates.io

API Docs

Installation

[dependencies]
baildon = "0.1"

Examples

There are a few simple examples to show how to use the library:

cargo run --example hello
cargo run --example streaming

Benchmarks

I've got some very simple benchmarks that I've used during development to look for regressions. I'll aim to improve these at some point.

cargo bench --bench baildon

License

Apache 2.0 licensed. See LICENSE for details.

Commit count: 15

cargo fmt