Skip to content

Commit

Permalink
Fix all errors and most warnings
Browse files Browse the repository at this point in the history
  • Loading branch information
Kerollmops committed Nov 17, 2024
1 parent ef5f5bc commit 92dbe08
Show file tree
Hide file tree
Showing 11 changed files with 423 additions and 492 deletions.
67 changes: 24 additions & 43 deletions heed/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,28 +1,34 @@
[package]
name = "heed"
version = "0.20.5"
name = "heed3"
version = "0.20.5-beta.1"
authors = ["Kerollmops <[email protected]>"]
description = "A fully typed LMDB (mdb.master) wrapper with minimum overhead"
description = "A fully typed LMDB (mdb.master3) wrapper with minimum overhead with support for encryption"
license = "MIT"
repository = "https://github.com/Kerollmops/heed"
keywords = ["lmdb", "database", "storage", "typed"]
keywords = ["lmdb", "database", "storage", "typed", "encryption"]
categories = ["database", "data-structures"]
readme = "../README.md"
edition = "2021"

[dependencies]
# TODO update dependencies
aead = { version = "0.5.1", default-features = false }
bitflags = { version = "2.6.0", features = ["serde"] }
byteorder = { version = "1.5.0", default-features = false }
generic-array = { version = "0.14.6", features = ["serde"] }
heed-traits = { version = "0.20.0", path = "../heed-traits" }
heed-types = { version = "0.20.1", default-features = false, path = "../heed-types" }
libc = "0.2.155"
lmdb-master-sys = { version = "0.2.4", path = "../lmdb-master-sys" }
lmdb-master3-sys = { version = "0.2.4", path = "../lmdb-master3-sys" }
once_cell = "1.19.0"
page_size = "0.6.0"
serde = { version = "1.0.203", features = ["derive"], optional = true }

[dev-dependencies]
# TODO update dependencies
argon2 = { version = "0.4.1", features = ["std"] }
serde = { version = "1.0.203", features = ["derive"] }
chacha20poly1305 = "0.10.1"
tempfile = "3.10.1"

[target.'cfg(windows)'.dependencies]
Expand Down Expand Up @@ -67,7 +73,7 @@ unbounded_depth = ["heed-types/unbounded_depth"]
# There are tradeoffs for both POSIX and SysV semaphores; which you
# should look into before enabling this feature. Also, see here:
# <https://github.com/LMDB/lmdb/blob/3947014aed7ffe39a79991fa7fb5b234da47ad1a/libraries/liblmdb/lmdb.h#L46-L69>
posix-sem = ["lmdb-master-sys/posix-sem"]
posix-sem = ["lmdb-master3-sys/posix-sem"]

# These features configure the MDB_IDL_LOGN macro, which determines
# the size of the free and dirty page lists (and thus the amount of memory
Expand All @@ -79,15 +85,15 @@ posix-sem = ["lmdb-master-sys/posix-sem"]
#
# For more information on the motivation for these features (and their effect),
# see https://github.com/mozilla/lmdb/pull/2.
mdb_idl_logn_8 = ["lmdb-master-sys/mdb_idl_logn_8"]
mdb_idl_logn_9 = ["lmdb-master-sys/mdb_idl_logn_9"]
mdb_idl_logn_10 = ["lmdb-master-sys/mdb_idl_logn_10"]
mdb_idl_logn_11 = ["lmdb-master-sys/mdb_idl_logn_11"]
mdb_idl_logn_12 = ["lmdb-master-sys/mdb_idl_logn_12"]
mdb_idl_logn_13 = ["lmdb-master-sys/mdb_idl_logn_13"]
mdb_idl_logn_14 = ["lmdb-master-sys/mdb_idl_logn_14"]
mdb_idl_logn_15 = ["lmdb-master-sys/mdb_idl_logn_15"]
mdb_idl_logn_16 = ["lmdb-master-sys/mdb_idl_logn_16"]
mdb_idl_logn_8 = ["lmdb-master3-sys/mdb_idl_logn_8"]
mdb_idl_logn_9 = ["lmdb-master3-sys/mdb_idl_logn_9"]
mdb_idl_logn_10 = ["lmdb-master3-sys/mdb_idl_logn_10"]
mdb_idl_logn_11 = ["lmdb-master3-sys/mdb_idl_logn_11"]
mdb_idl_logn_12 = ["lmdb-master3-sys/mdb_idl_logn_12"]
mdb_idl_logn_13 = ["lmdb-master3-sys/mdb_idl_logn_13"]
mdb_idl_logn_14 = ["lmdb-master3-sys/mdb_idl_logn_14"]
mdb_idl_logn_15 = ["lmdb-master3-sys/mdb_idl_logn_15"]
mdb_idl_logn_16 = ["lmdb-master3-sys/mdb_idl_logn_16"]

# Setting this enables you to use keys longer than 511 bytes. The exact limit
# is computed by LMDB at compile time. You can find the exact value by calling
Expand All @@ -107,35 +113,10 @@ mdb_idl_logn_16 = ["lmdb-master-sys/mdb_idl_logn_16"]
# stored key must fit within the smallest limit of all architectures used. For
# example, if you are moving databases between Apple M1 and Apple Intel
# computers then you need to keep your keys within the smaller 1982 byte limit.
longer-keys = ["lmdb-master-sys/longer-keys"]
longer-keys = ["lmdb-master3-sys/longer-keys"]

# Examples are located outside the standard heed/examples directory to prevent
# conflicts between heed3 and heed examples when working on both crates.
[[example]]
name = "all-types"
path = "../examples/all-types.rs"

[[example]]
name = "clear-database"
path = "../examples/clear-database.rs"

[[example]]
name = "cursor-append"
path = "../examples/cursor-append.rs"

[[example]]
name = "custom-comparator"
path = "../examples/custom-comparator.rs"

[[example]]
name = "multi-env"
path = "../examples/multi-env.rs"

[[example]]
name = "nested"
path = "../examples/nested.rs"

[[example]]
name = "rmp-serde"
path = "../examples/rmp-serde.rs"
required-features = ["serde-rmp"]
name = "heed3-encryption"
path = "../examples/heed3-encryption.rs"
32 changes: 16 additions & 16 deletions heed/src/cookbook.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@
//! use std::fs;
//! use std::path::Path;
//!
//! use heed::types::*;
//! use heed::{Database, EnvOpenOptions};
//! use heed3::types::*;
//! use heed3::{Database, EnvOpenOptions};
//!
//! pub type StringMap = HashMap<String, String>;
//!
Expand Down Expand Up @@ -57,9 +57,9 @@
//! }
//!
//! fn fill_with_data(
//! wtxn: &mut heed::RwTxn,
//! wtxn: &mut heed3::RwTxn,
//! db: Database<Str, SerdeJson<StringMap>>,
//! ) -> heed::Result<()> {
//! ) -> heed3::Result<()> {
//! // This represents a very big value that we only want to decode when necessary.
//! let mut big_string_map = HashMap::new();
//! big_string_map.insert("key1".into(), "I am a very long string".into());
Expand Down Expand Up @@ -88,8 +88,8 @@
//! use std::fs;
//! use std::path::Path;
//!
//! use heed::types::*;
//! use heed::{Database, EnvOpenOptions};
//! use heed3::types::*;
//! use heed3::{Database, EnvOpenOptions};
//!
//! fn main() -> Result<(), Box<dyn Error>> {
//! let env_path = Path::new("target").join("heed.mdb");
Expand Down Expand Up @@ -151,8 +151,8 @@
//! use std::fs;
//! use std::path::Path;
//!
//! use heed::types::*;
//! use heed::{BoxedError, BytesDecode, BytesEncode, Database, EnvOpenOptions};
//! use heed3::types::*;
//! use heed3::{BoxedError, BytesDecode, BytesEncode, Database, EnvOpenOptions};
//!
//! #[derive(Debug, PartialEq, Eq)]
//! pub enum Level {
Expand Down Expand Up @@ -294,8 +294,8 @@
//! use std::fs;
//! use std::path::Path;
//!
//! use heed::types::*;
//! use heed::{Database, EnvOpenOptions};
//! use heed3::types::*;
//! use heed3::{Database, EnvOpenOptions};
//!
//! fn main() -> Result<(), Box<dyn Error>> {
//! let path = Path::new("target").join("small-space.mdb");
Expand All @@ -314,7 +314,7 @@
//! // Ho! Crap! We don't have enough space in this environment...
//! assert!(matches!(
//! fill_with_data(&mut wtxn, db),
//! Err(heed::Error::Mdb(heed::MdbError::MapFull))
//! Err(heed3::Error::Mdb(heed3::MdbError::MapFull))
//! ));
//!
//! drop(wtxn);
Expand All @@ -338,7 +338,7 @@
//! Ok(())
//! }
//!
//! fn fill_with_data(wtxn: &mut heed::RwTxn, db: Database<Str, Str>) -> heed::Result<()> {
//! fn fill_with_data(wtxn: &mut heed3::RwTxn, db: Database<Str, Str>) -> heed3::Result<()> {
//! for i in 0..1000 {
//! let key = i.to_string();
//! db.put(wtxn, &key, "I am a very long string")?;
Expand Down Expand Up @@ -373,8 +373,8 @@
//! use std::fs;
//! use std::path::Path;
//!
//! use heed::types::*;
//! use heed::{Database, EnvOpenOptions, RoTxn};
//! use heed3::types::*;
//! use heed3::{Database, EnvOpenOptions, RoTxn};
//!
//! fn main() -> Result<(), Box<dyn Error + Send + Sync>> {
//! let path = Path::new("target").join("heed.mdb");
Expand Down Expand Up @@ -415,7 +415,7 @@
//! Ok(())
//! }
//!
//! fn fill_with_data(wtxn: &mut heed::RwTxn, db: Database<Str, Str>) -> heed::Result<()> {
//! fn fill_with_data(wtxn: &mut heed3::RwTxn, db: Database<Str, Str>) -> heed3::Result<()> {
//! for i in 0..100 {
//! let key = i.to_string();
//! db.put(wtxn, &key, "I am a very long string")?;
Expand All @@ -428,7 +428,7 @@
//! }
//!
//! impl<'t> ImmutableMap<'t> {
//! fn from_db(rtxn: &'t RoTxn, db: Database<Str, Str>) -> heed::Result<Self> {
//! fn from_db(rtxn: &'t RoTxn, db: Database<Str, Str>) -> heed3::Result<Self> {
//! let mut map = HashMap::new();
//! for result in db.iter(rtxn)? {
//! let (k, v) = result?;
Expand Down
Loading

0 comments on commit 92dbe08

Please sign in to comment.