From cf8a24c2bdb3a32988359b98044c045bb0a73fc6 Mon Sep 17 00:00:00 2001 From: Paul Hauner Date: Wed, 1 May 2019 14:29:03 +1000 Subject: [PATCH] Add enc/decode traits to store --- beacon_node/db2/src/impls.rs | 16 +++++++++++++++ beacon_node/db2/src/lib.rs | 38 +++++++++++++++++++++++++----------- 2 files changed, 43 insertions(+), 11 deletions(-) create mode 100644 beacon_node/db2/src/impls.rs diff --git a/beacon_node/db2/src/impls.rs b/beacon_node/db2/src/impls.rs new file mode 100644 index 000000000..9e607ddf5 --- /dev/null +++ b/beacon_node/db2/src/impls.rs @@ -0,0 +1,16 @@ +/* +use types::*; + +impl StoreEncode for Hash256 { + fn as_store_bytes(&self) -> Vec { + self.as_bytes().to_vec() + } +} + +impl StoreDecode for Hash256 { + fn from_store_bytes(bytes: &mut [u8]) -> Vec { + Hash256::from_slice() + self.as_bytes().to_vec() + } +} +*/ diff --git a/beacon_node/db2/src/lib.rs b/beacon_node/db2/src/lib.rs index da00262e6..3bff89512 100644 --- a/beacon_node/db2/src/lib.rs +++ b/beacon_node/db2/src/lib.rs @@ -1,9 +1,8 @@ // mod disk_db; mod errors; +mod impls; mod memory_db; -use db_encode::{db_encode, DBDecode, DBEncode}; - pub use self::memory_db::MemoryDB; pub use errors::Error; pub use types::*; @@ -35,6 +34,14 @@ pub trait Store: Sync + Send + Sized { fn key_delete(&self, col: &str, key: &[u8]) -> Result<(), Error>; } +pub trait StoreEncode { + fn as_store_bytes(&self) -> Vec; +} + +pub trait StoreDecode: Sized { + fn from_store_bytes(bytes: &mut [u8]) -> Result; +} + pub enum DBColumn { Block, State, @@ -52,7 +59,7 @@ impl<'a> Into<&'a str> for DBColumn { } } -pub trait StorableItem: DBEncode + DBDecode { +pub trait StorableItem: StoreEncode + StoreDecode + Sized { fn db_column() -> DBColumn; fn db_put(&self, store: &impl Store, key: &Hash256) -> Result<(), Error> { @@ -60,7 +67,7 @@ pub trait StorableItem: DBEncode + DBDecode { let key = key.as_bytes(); store - .put_bytes(column, key, &db_encode(self)) + .put_bytes(column, key, &self.as_store_bytes()) .map_err(|e| e.into()) } @@ -69,10 +76,7 @@ pub trait StorableItem: DBEncode + DBDecode { let key = key.as_bytes(); match store.get_bytes(column, key)? { - Some(bytes) => { - let (item, _index) = Self::db_decode(&bytes, 0)?; - Ok(Some(item)) - } + Some(mut bytes) => Ok(Some(Self::from_store_bytes(&mut bytes[..])?)), None => Ok(None), } } @@ -95,16 +99,28 @@ pub trait StorableItem: DBEncode + DBDecode { #[cfg(test)] mod tests { use super::*; - use db_encode_derive::{DBDecode, DBEncode}; - use ssz::Decodable; + use ssz::{ssz_encode, Decodable}; use ssz_derive::{Decode, Encode}; - #[derive(PartialEq, Debug, Encode, Decode, DBEncode, DBDecode)] + #[derive(PartialEq, Debug, Encode, Decode)] struct StorableThing { a: u64, b: u64, } + impl StoreEncode for StorableThing { + fn as_store_bytes(&self) -> Vec { + ssz_encode(self) + } + } + + impl StoreDecode for StorableThing { + fn from_store_bytes(bytes: &mut [u8]) -> Result { + let (item, _) = Self::ssz_decode(bytes, 0)?; + Ok(item) + } + } + impl StorableItem for StorableThing { fn db_column() -> DBColumn { DBColumn::Block