hyperbee 0.3.0

Peer to Peer B-tree
Documentation
# Hyperbee
# ⚠️  WARNING 🚧 API unstable ⚒️  and still in development 👷

A peer-to-peer append-only B-tree built on Hypercore. Compatible with the [JavaScript version](https://github.com/holepunchto/hyperbee).
```
$ cargo add hyperbee
```

# Usage

From the [examples](/examples/ram.rs):

```rust
use hyperbee::Hyperbee;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let hb = Hyperbee::from_ram().await?;
    // Insert "world" with key "hello"
    hb.put(b"hello", Some(b"world")).await?;

    // Get the value for key "hello"
    let Some((_seq, Some(val))) = hb.get(b"hello").await? else {
        panic!("could not get value");
    };
    assert_eq!(val, b"world");

    // Trying to get a non-exsitant key returns `None`
    let res = hb.get(b"no key here").await?;
    assert_eq!(res, None);

    // Deleting a key returns `true` if it was present
    let res = hb.del(b"hello").await?;
    assert!(res.is_some());

    // Getting deleted key returns `None`
    let res = hb.get(b"hello").await?;
    assert_eq!(res, None);

    Ok(())
}
```

## Parity with JS Hyperbee

- [x] full functional interoperability with JS Hyperbee files
- [x] read, write, and delete operations
- [x] in-order key streaming like JS's [`createReadStream`]https://docs.holepunch.to/building-blocks/hyperbee#const-stream-db.createreadstream-range-options
- [x] support `gt`, `lt`,  etc bounds for key streaming
- [x] accept compare-and-swap for `put` and `del`.
- [x] support prefixed key operations like JS's [`sub`]https://docs.holepunch.to/building-blocks/hyperbee#const-sub-db.sub-sub-prefix-options
- [ ] one-to-one binary output

## Future work

- [ ] Build FFI wrappers
- [ ] improved wire format
- [ ] configurable tree parameters

## Development

Integration tests use data generated by JavaScript code in `gen_test_data`. Generate the test data with:
```
$ cd gen_test_data && yarn install && yarn node index.js && popd
```

Then you can run the tests with `$ cargo test`.