triehash is separated from util (#6428)
This commit is contained in:
parent
7b8af30590
commit
b731ccea18
13
Cargo.lock
generated
13
Cargo.lock
generated
@ -543,6 +543,7 @@ dependencies = [
|
|||||||
"table 0.1.0",
|
"table 0.1.0",
|
||||||
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"transient-hashmap 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"transient-hashmap 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"triehash 0.1.0",
|
||||||
"using_queue 0.1.0",
|
"using_queue 0.1.0",
|
||||||
"vm 0.1.0",
|
"vm 0.1.0",
|
||||||
"wasm 0.1.0",
|
"wasm 0.1.0",
|
||||||
@ -672,6 +673,7 @@ dependencies = [
|
|||||||
"smallvec 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"smallvec 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"stats 0.1.0",
|
"stats 0.1.0",
|
||||||
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"triehash 0.1.0",
|
||||||
"vm 0.1.0",
|
"vm 0.1.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -807,6 +809,7 @@ dependencies = [
|
|||||||
"target_info 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"target_info 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"tiny-keccak 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"tiny-keccak 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"triehash 0.1.0",
|
||||||
"vergen 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"vergen 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -922,6 +925,7 @@ dependencies = [
|
|||||||
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"smallvec 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"smallvec 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"triehash 0.1.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -3106,6 +3110,15 @@ dependencies = [
|
|||||||
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
"time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "triehash"
|
||||||
|
version = "0.1.0"
|
||||||
|
dependencies = [
|
||||||
|
"ethcore-bigint 0.1.3",
|
||||||
|
"hash 0.1.0",
|
||||||
|
"rlp 0.2.0",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "typeable"
|
name = "typeable"
|
||||||
version = "0.1.2"
|
version = "0.1.2"
|
||||||
|
@ -63,6 +63,7 @@ bloomable = { path = "../util/bloomable" }
|
|||||||
vm = { path = "vm" }
|
vm = { path = "vm" }
|
||||||
wasm = { path = "wasm" }
|
wasm = { path = "wasm" }
|
||||||
hash = { path = "../util/hash" }
|
hash = { path = "../util/hash" }
|
||||||
|
triehash = { path = "../util/triehash" }
|
||||||
semantic_version = { path = "../util/semantic_version" }
|
semantic_version = { path = "../util/semantic_version" }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
|
@ -34,6 +34,7 @@ serde_derive = "1.0"
|
|||||||
parking_lot = "0.4"
|
parking_lot = "0.4"
|
||||||
stats = { path = "../../util/stats" }
|
stats = { path = "../../util/stats" }
|
||||||
hash = { path = "../../util/hash" }
|
hash = { path = "../../util/hash" }
|
||||||
|
triehash = { path = "../../util/triehash" }
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = []
|
default = []
|
||||||
|
@ -130,7 +130,7 @@ pub fn compute_root<I>(cht_num: u64, iterable: I) -> Option<H256>
|
|||||||
}
|
}
|
||||||
|
|
||||||
if v.len() == SIZE as usize {
|
if v.len() == SIZE as usize {
|
||||||
Some(::util::triehash::trie_root(v))
|
Some(::triehash::trie_root(v))
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
@ -86,6 +86,7 @@ extern crate stats;
|
|||||||
extern crate time;
|
extern crate time;
|
||||||
extern crate vm;
|
extern crate vm;
|
||||||
extern crate hash;
|
extern crate hash;
|
||||||
|
extern crate triehash;
|
||||||
|
|
||||||
#[cfg(feature = "ipc")]
|
#[cfg(feature = "ipc")]
|
||||||
extern crate ethcore_ipc as ipc;
|
extern crate ethcore_ipc as ipc;
|
||||||
|
@ -709,7 +709,7 @@ impl Body {
|
|||||||
pub fn check_response(&self, cache: &Mutex<::cache::Cache>, body: &encoded::Body) -> Result<encoded::Block, Error> {
|
pub fn check_response(&self, cache: &Mutex<::cache::Cache>, body: &encoded::Body) -> Result<encoded::Block, Error> {
|
||||||
// check the integrity of the the body against the header
|
// check the integrity of the the body against the header
|
||||||
let header = self.0.as_ref()?;
|
let header = self.0.as_ref()?;
|
||||||
let tx_root = ::util::triehash::ordered_trie_root(body.rlp().at(0).iter().map(|r| r.as_raw().to_vec()));
|
let tx_root = ::triehash::ordered_trie_root(body.rlp().at(0).iter().map(|r| r.as_raw().to_vec()));
|
||||||
if tx_root != header.transactions_root() {
|
if tx_root != header.transactions_root() {
|
||||||
return Err(Error::WrongTrieRoot(header.transactions_root(), tx_root));
|
return Err(Error::WrongTrieRoot(header.transactions_root(), tx_root));
|
||||||
}
|
}
|
||||||
@ -739,7 +739,7 @@ impl BlockReceipts {
|
|||||||
/// Check a response with receipts against the stored header.
|
/// Check a response with receipts against the stored header.
|
||||||
pub fn check_response(&self, cache: &Mutex<::cache::Cache>, receipts: &[Receipt]) -> Result<Vec<Receipt>, Error> {
|
pub fn check_response(&self, cache: &Mutex<::cache::Cache>, receipts: &[Receipt]) -> Result<Vec<Receipt>, Error> {
|
||||||
let receipts_root = self.0.as_ref()?.receipts_root();
|
let receipts_root = self.0.as_ref()?.receipts_root();
|
||||||
let found_root = ::util::triehash::ordered_trie_root(receipts.iter().map(|r| ::rlp::encode(r).into_vec()));
|
let found_root = ::triehash::ordered_trie_root(receipts.iter().map(|r| ::rlp::encode(r).into_vec()));
|
||||||
|
|
||||||
match receipts_root == found_root {
|
match receipts_root == found_root {
|
||||||
true => {
|
true => {
|
||||||
@ -936,7 +936,7 @@ mod tests {
|
|||||||
}).collect::<Vec<_>>();
|
}).collect::<Vec<_>>();
|
||||||
|
|
||||||
let mut header = Header::new();
|
let mut header = Header::new();
|
||||||
let receipts_root = ::util::triehash::ordered_trie_root(
|
let receipts_root = ::triehash::ordered_trie_root(
|
||||||
receipts.iter().map(|x| ::rlp::encode(x).into_vec())
|
receipts.iter().map(|x| ::rlp::encode(x).into_vec())
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -20,9 +20,10 @@ use std::cmp;
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
use hash::{keccak, KECCAK_NULL_RLP, KECCAK_EMPTY_LIST_RLP};
|
use hash::{keccak, KECCAK_NULL_RLP, KECCAK_EMPTY_LIST_RLP};
|
||||||
|
use triehash::ordered_trie_root;
|
||||||
|
|
||||||
use rlp::{UntrustedRlp, RlpStream, Encodable, Decodable, DecoderError};
|
use rlp::{UntrustedRlp, RlpStream, Encodable, Decodable, DecoderError};
|
||||||
use util::{Bytes, Address, U256, H256, ordered_trie_root};
|
use util::{Bytes, Address, U256, H256};
|
||||||
use util::error::{Mismatch, OutOfBounds};
|
use util::error::{Mismatch, OutOfBounds};
|
||||||
|
|
||||||
use basic_types::{LogBloom, Seal};
|
use basic_types::{LogBloom, Seal};
|
||||||
|
@ -353,7 +353,7 @@ impl ValidatorSet for ValidatorSafeContract {
|
|||||||
|
|
||||||
// ensure receipts match header.
|
// ensure receipts match header.
|
||||||
// TODO: optimize? these were just decoded.
|
// TODO: optimize? these were just decoded.
|
||||||
let found_root = ::util::triehash::ordered_trie_root(
|
let found_root = ::triehash::ordered_trie_root(
|
||||||
receipts.iter().map(::rlp::encode).map(|x| x.to_vec())
|
receipts.iter().map(::rlp::encode).map(|x| x.to_vec())
|
||||||
);
|
);
|
||||||
if found_root != *old_header.receipts_root() {
|
if found_root != *old_header.receipts_root() {
|
||||||
|
@ -104,6 +104,7 @@ extern crate rand;
|
|||||||
extern crate rlp;
|
extern crate rlp;
|
||||||
extern crate hash;
|
extern crate hash;
|
||||||
extern crate heapsize;
|
extern crate heapsize;
|
||||||
|
extern crate triehash;
|
||||||
extern crate ansi_term;
|
extern crate ansi_term;
|
||||||
extern crate semantic_version;
|
extern crate semantic_version;
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@ use std::fmt;
|
|||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use hash::{keccak};
|
use hash::{keccak};
|
||||||
|
use triehash::sec_trie_root;
|
||||||
use util::*;
|
use util::*;
|
||||||
use state::Account;
|
use state::Account;
|
||||||
use ethjson;
|
use ethjson;
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
|
use triehash::sec_trie_root;
|
||||||
use util::*;
|
use util::*;
|
||||||
use pod_account::{self, PodAccount};
|
use pod_account::{self, PodAccount};
|
||||||
use types::state_diff::StateDiff;
|
use types::state_diff::StateDiff;
|
||||||
|
@ -23,7 +23,7 @@ use hash::keccak;
|
|||||||
use views::BlockView;
|
use views::BlockView;
|
||||||
use rlp::{DecoderError, RlpStream, UntrustedRlp};
|
use rlp::{DecoderError, RlpStream, UntrustedRlp};
|
||||||
use util::{Bytes, H256};
|
use util::{Bytes, H256};
|
||||||
use util::triehash::ordered_trie_root;
|
use triehash::ordered_trie_root;
|
||||||
|
|
||||||
const HEADER_FIELDS: usize = 8;
|
const HEADER_FIELDS: usize = 8;
|
||||||
const BLOCK_FIELDS: usize = 2;
|
const BLOCK_FIELDS: usize = 2;
|
||||||
@ -190,7 +190,7 @@ mod tests {
|
|||||||
b.transactions.push(t2.into());
|
b.transactions.push(t2.into());
|
||||||
|
|
||||||
let receipts_root = b.header.receipts_root().clone();
|
let receipts_root = b.header.receipts_root().clone();
|
||||||
b.header.set_transactions_root(::util::triehash::ordered_trie_root(
|
b.header.set_transactions_root(::triehash::ordered_trie_root(
|
||||||
b.transactions.iter().map(::rlp::encode).map(|out| out.into_vec())
|
b.transactions.iter().map(::rlp::encode).map(|out| out.into_vec())
|
||||||
));
|
));
|
||||||
|
|
||||||
|
@ -222,7 +222,7 @@ impl Rebuilder for PowRebuilder {
|
|||||||
use views::BlockView;
|
use views::BlockView;
|
||||||
use snapshot::verify_old_block;
|
use snapshot::verify_old_block;
|
||||||
use util::U256;
|
use util::U256;
|
||||||
use util::triehash::ordered_trie_root;
|
use triehash::ordered_trie_root;
|
||||||
|
|
||||||
let rlp = UntrustedRlp::new(chunk);
|
let rlp = UntrustedRlp::new(chunk);
|
||||||
let item_count = rlp.item_count()?;
|
let item_count = rlp.item_count()?;
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
use hash::keccak;
|
use hash::keccak;
|
||||||
|
use triehash::ordered_trie_root;
|
||||||
use heapsize::HeapSizeOf;
|
use heapsize::HeapSizeOf;
|
||||||
use util::*;
|
use util::*;
|
||||||
use engines::Engine;
|
use engines::Engine;
|
||||||
@ -269,6 +270,7 @@ fn verify_block_integrity(block: &[u8], transactions_root: &H256, uncles_hash: &
|
|||||||
mod tests {
|
mod tests {
|
||||||
use std::collections::{BTreeMap, HashMap};
|
use std::collections::{BTreeMap, HashMap};
|
||||||
use hash::keccak;
|
use hash::keccak;
|
||||||
|
use triehash::ordered_trie_root;
|
||||||
use util::*;
|
use util::*;
|
||||||
use ethkey::{Random, Generator};
|
use ethkey::{Random, Generator};
|
||||||
use header::*;
|
use header::*;
|
||||||
|
@ -19,6 +19,7 @@ ethcore-light = { path = "../ethcore/light"}
|
|||||||
ethcore = { path = "../ethcore" }
|
ethcore = { path = "../ethcore" }
|
||||||
rlp = { path = "../util/rlp" }
|
rlp = { path = "../util/rlp" }
|
||||||
hash = { path = "../util/hash" }
|
hash = { path = "../util/hash" }
|
||||||
|
triehash = { path = "../util/triehash" }
|
||||||
clippy = { version = "0.0.103", optional = true}
|
clippy = { version = "0.0.103", optional = true}
|
||||||
log = "0.3"
|
log = "0.3"
|
||||||
env_logger = "0.4"
|
env_logger = "0.4"
|
||||||
|
@ -19,6 +19,7 @@ use std::collections::hash_map::Entry;
|
|||||||
use smallvec::SmallVec;
|
use smallvec::SmallVec;
|
||||||
use hash::{keccak, KECCAK_NULL_RLP, KECCAK_EMPTY_LIST_RLP};
|
use hash::{keccak, KECCAK_NULL_RLP, KECCAK_EMPTY_LIST_RLP};
|
||||||
use heapsize::HeapSizeOf;
|
use heapsize::HeapSizeOf;
|
||||||
|
use triehash::ordered_trie_root;
|
||||||
use util::*;
|
use util::*;
|
||||||
use rlp::*;
|
use rlp::*;
|
||||||
use network::NetworkError;
|
use network::NetworkError;
|
||||||
|
@ -39,6 +39,7 @@ extern crate smallvec;
|
|||||||
extern crate rlp;
|
extern crate rlp;
|
||||||
extern crate ipnetwork;
|
extern crate ipnetwork;
|
||||||
extern crate hash;
|
extern crate hash;
|
||||||
|
extern crate triehash;
|
||||||
|
|
||||||
extern crate ethcore_light as light;
|
extern crate ethcore_light as light;
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@ ethcore-bloom-journal = { path = "bloom" }
|
|||||||
regex = "0.2"
|
regex = "0.2"
|
||||||
lru-cache = "0.1.0"
|
lru-cache = "0.1.0"
|
||||||
ethcore-logger = { path = "../logger" }
|
ethcore-logger = { path = "../logger" }
|
||||||
|
triehash = { path = "triehash" }
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = []
|
default = []
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
#![feature(test)]
|
#![feature(test)]
|
||||||
|
|
||||||
extern crate test;
|
extern crate test;
|
||||||
|
extern crate triehash;
|
||||||
extern crate ethcore_util;
|
extern crate ethcore_util;
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate log;
|
extern crate log;
|
||||||
@ -27,7 +28,7 @@ use ethcore_util::hash::*;
|
|||||||
use ethcore_util::bytes::*;
|
use ethcore_util::bytes::*;
|
||||||
use ethcore_util::trie::*;
|
use ethcore_util::trie::*;
|
||||||
use ethcore_util::memorydb::*;
|
use ethcore_util::memorydb::*;
|
||||||
use ethcore_util::triehash::*;
|
use triehash::*;
|
||||||
use hash::keccak;
|
use hash::keccak;
|
||||||
|
|
||||||
fn random_word(alphabet: &[u8], min_count: usize, diff_count: usize, seed: &mut H256) -> Vec<u8> {
|
fn random_word(alphabet: &[u8], min_count: usize, diff_count: usize, seed: &mut H256) -> Vec<u8> {
|
||||||
|
@ -117,14 +117,12 @@ pub mod common;
|
|||||||
pub mod error;
|
pub mod error;
|
||||||
pub mod bytes;
|
pub mod bytes;
|
||||||
pub mod misc;
|
pub mod misc;
|
||||||
pub mod vector;
|
|
||||||
pub mod hashdb;
|
pub mod hashdb;
|
||||||
pub mod memorydb;
|
pub mod memorydb;
|
||||||
pub mod migration;
|
pub mod migration;
|
||||||
pub mod overlaydb;
|
pub mod overlaydb;
|
||||||
pub mod journaldb;
|
pub mod journaldb;
|
||||||
pub mod kvdb;
|
pub mod kvdb;
|
||||||
pub mod triehash;
|
|
||||||
pub mod trie;
|
pub mod trie;
|
||||||
pub mod nibbleslice;
|
pub mod nibbleslice;
|
||||||
pub mod nibblevec;
|
pub mod nibblevec;
|
||||||
@ -136,12 +134,10 @@ pub use hashdb::*;
|
|||||||
pub use memorydb::MemoryDB;
|
pub use memorydb::MemoryDB;
|
||||||
pub use overlaydb::*;
|
pub use overlaydb::*;
|
||||||
pub use journaldb::JournalDB;
|
pub use journaldb::JournalDB;
|
||||||
pub use triehash::*;
|
|
||||||
pub use trie::{Trie, TrieMut, TrieDB, TrieDBMut, TrieFactory, TrieError, SecTrieDB, SecTrieDBMut};
|
pub use trie::{Trie, TrieMut, TrieDB, TrieDBMut, TrieFactory, TrieError, SecTrieDB, SecTrieDBMut};
|
||||||
pub use kvdb::*;
|
pub use kvdb::*;
|
||||||
pub use error::*;
|
pub use error::*;
|
||||||
pub use bytes::*;
|
pub use bytes::*;
|
||||||
pub use vector::*;
|
|
||||||
pub use bigint::prelude::*;
|
pub use bigint::prelude::*;
|
||||||
pub use bigint::hash;
|
pub use bigint::hash;
|
||||||
|
|
||||||
|
@ -937,7 +937,8 @@ impl<'a> Drop for TrieDBMut<'a> {
|
|||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use triehash::trie_root;
|
extern crate triehash;
|
||||||
|
use self::triehash::trie_root;
|
||||||
use hashdb::*;
|
use hashdb::*;
|
||||||
use memorydb::*;
|
use memorydb::*;
|
||||||
use super::*;
|
use super::*;
|
||||||
|
@ -1,68 +0,0 @@
|
|||||||
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
|
||||||
// This file is part of Parity.
|
|
||||||
|
|
||||||
// Parity is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
|
|
||||||
// Parity is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
//! Vector extensions.
|
|
||||||
|
|
||||||
/// Returns len of prefix shared with elem
|
|
||||||
///
|
|
||||||
/// ```rust
|
|
||||||
/// extern crate ethcore_util as util;
|
|
||||||
/// use util::vector::SharedPrefix;
|
|
||||||
///
|
|
||||||
/// fn main () {
|
|
||||||
/// let a = vec![1,2,3,3,5];
|
|
||||||
/// let b = vec![1,2,3];
|
|
||||||
/// assert_eq!(a.shared_prefix_len(&b), 3);
|
|
||||||
/// }
|
|
||||||
/// ```
|
|
||||||
pub trait SharedPrefix<T> {
|
|
||||||
/// Get common prefix length
|
|
||||||
fn shared_prefix_len(&self, elem: &[T]) -> usize;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T> SharedPrefix<T> for [T] where T: Eq {
|
|
||||||
fn shared_prefix_len(&self, elem: &[T]) -> usize {
|
|
||||||
use std::cmp;
|
|
||||||
let len = cmp::min(self.len(), elem.len());
|
|
||||||
(0..len).take_while(|&i| self[i] == elem[i]).count()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod test {
|
|
||||||
use vector::SharedPrefix;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_shared_prefix() {
|
|
||||||
let a = vec![1,2,3,4,5,6];
|
|
||||||
let b = vec![4,2,3,4,5,6];
|
|
||||||
assert_eq!(a.shared_prefix_len(&b), 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_shared_prefix2() {
|
|
||||||
let a = vec![1,2,3,3,5];
|
|
||||||
let b = vec![1,2,3];
|
|
||||||
assert_eq!(a.shared_prefix_len(&b), 3);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_shared_prefix3() {
|
|
||||||
let a = vec![1,2,3,4,5,6];
|
|
||||||
let b = vec![1,2,3,4,5,6];
|
|
||||||
assert_eq!(a.shared_prefix_len(&b), 6);
|
|
||||||
}
|
|
||||||
}
|
|
9
util/triehash/Cargo.toml
Normal file
9
util/triehash/Cargo.toml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
[package]
|
||||||
|
name = "triehash"
|
||||||
|
version = "0.1.0"
|
||||||
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
rlp = { path = "../rlp" }
|
||||||
|
ethcore-bigint = { path = "../bigint" }
|
||||||
|
hash = { path = "../hash" }
|
@ -18,26 +18,31 @@
|
|||||||
//!
|
//!
|
||||||
//! This module should be used to generate trie root hash.
|
//! This module should be used to generate trie root hash.
|
||||||
|
|
||||||
|
extern crate ethcore_bigint;
|
||||||
|
extern crate hash;
|
||||||
|
extern crate rlp;
|
||||||
|
|
||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
use std::cmp;
|
use std::cmp;
|
||||||
use hash::*;
|
use ethcore_bigint::hash::H256;
|
||||||
use keccak::keccak;
|
use hash::keccak;
|
||||||
use rlp;
|
|
||||||
use rlp::RlpStream;
|
use rlp::RlpStream;
|
||||||
use vector::SharedPrefix;
|
|
||||||
|
fn shared_prefix_len<T: Eq>(first: &[T], second: &[T]) -> usize {
|
||||||
|
let len = cmp::min(first.len(), second.len());
|
||||||
|
(0..len).take_while(|&i| first[i] == second[i]).count()
|
||||||
|
}
|
||||||
|
|
||||||
/// Generates a trie root hash for a vector of values
|
/// Generates a trie root hash for a vector of values
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate ethcore_util as util;
|
/// extern crate triehash;
|
||||||
/// use std::str::FromStr;
|
/// use triehash::ordered_trie_root;
|
||||||
/// use util::triehash::*;
|
|
||||||
/// use util::hash::*;
|
|
||||||
///
|
///
|
||||||
/// fn main() {
|
/// fn main() {
|
||||||
/// let v = vec![From::from("doe"), From::from("reindeer")];
|
/// let v = vec![From::from("doe"), From::from("reindeer")];
|
||||||
/// let root = "e766d5d51b89dc39d981b41bda63248d7abce4f0225eefd023792a540bcffee3";
|
/// let root = "e766d5d51b89dc39d981b41bda63248d7abce4f0225eefd023792a540bcffee3";
|
||||||
/// assert_eq!(ordered_trie_root(v), H256::from_str(root).unwrap());
|
/// assert_eq!(ordered_trie_root(v), root.parse().unwrap());
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn ordered_trie_root<I>(input: I) -> H256
|
pub fn ordered_trie_root<I>(input: I) -> H256
|
||||||
@ -61,10 +66,8 @@ pub fn ordered_trie_root<I>(input: I) -> H256
|
|||||||
/// Generates a trie root hash for a vector of key-values
|
/// Generates a trie root hash for a vector of key-values
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate ethcore_util as util;
|
/// extern crate triehash;
|
||||||
/// use std::str::FromStr;
|
/// use triehash::trie_root;
|
||||||
/// use util::triehash::*;
|
|
||||||
/// use util::hash::*;
|
|
||||||
///
|
///
|
||||||
/// fn main() {
|
/// fn main() {
|
||||||
/// let v = vec![
|
/// let v = vec![
|
||||||
@ -74,7 +77,7 @@ pub fn ordered_trie_root<I>(input: I) -> H256
|
|||||||
/// ];
|
/// ];
|
||||||
///
|
///
|
||||||
/// let root = "8aad789dff2f538bca5d8ea56e8abe10f4c7ba3a5dea95fea4cd6e7c3a1168d3";
|
/// let root = "8aad789dff2f538bca5d8ea56e8abe10f4c7ba3a5dea95fea4cd6e7c3a1168d3";
|
||||||
/// assert_eq!(trie_root(v), H256::from_str(root).unwrap());
|
/// assert_eq!(trie_root(v), root.parse().unwrap());
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn trie_root<I>(input: I) -> H256
|
pub fn trie_root<I>(input: I) -> H256
|
||||||
@ -95,10 +98,8 @@ pub fn trie_root<I>(input: I) -> H256
|
|||||||
/// Generates a key-hashed (secure) trie root hash for a vector of key-values.
|
/// Generates a key-hashed (secure) trie root hash for a vector of key-values.
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate ethcore_util as util;
|
/// extern crate triehash;
|
||||||
/// use std::str::FromStr;
|
/// use triehash::sec_trie_root;
|
||||||
/// use util::triehash::*;
|
|
||||||
/// use util::hash::*;
|
|
||||||
///
|
///
|
||||||
/// fn main() {
|
/// fn main() {
|
||||||
/// let v = vec![
|
/// let v = vec![
|
||||||
@ -108,7 +109,7 @@ pub fn trie_root<I>(input: I) -> H256
|
|||||||
/// ];
|
/// ];
|
||||||
///
|
///
|
||||||
/// let root = "d4cd937e4a4368d7931a9cf51686b7e10abb3dce38a39000fd7902a092b64585";
|
/// let root = "d4cd937e4a4368d7931a9cf51686b7e10abb3dce38a39000fd7902a092b64585";
|
||||||
/// assert_eq!(sec_trie_root(v), H256::from_str(root).unwrap());
|
/// assert_eq!(sec_trie_root(v), root.parse().unwrap());
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn sec_trie_root(input: Vec<(Vec<u8>, Vec<u8>)>) -> H256 {
|
pub fn sec_trie_root(input: Vec<(Vec<u8>, Vec<u8>)>) -> H256 {
|
||||||
@ -216,7 +217,7 @@ fn hash256rlp(input: &[(Vec<u8>, Vec<u8>)], pre_len: usize, stream: &mut RlpStre
|
|||||||
.skip(1)
|
.skip(1)
|
||||||
// get minimum number of shared nibbles between first and each successive
|
// get minimum number of shared nibbles between first and each successive
|
||||||
.fold(key.len(), | acc, &(ref k, _) | {
|
.fold(key.len(), | acc, &(ref k, _) | {
|
||||||
cmp::min(key.shared_prefix_len(k), acc)
|
cmp::min(shared_prefix_len(key, k), acc)
|
||||||
});
|
});
|
||||||
|
|
||||||
// if shared prefix is higher than current prefix append its
|
// if shared prefix is higher than current prefix append its
|
||||||
@ -288,50 +289,49 @@ fn test_nibbles() {
|
|||||||
assert_eq!(as_nibbles(&v), e);
|
assert_eq!(as_nibbles(&v), e);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_hex_prefix_encode() {
|
|
||||||
let v = vec![0, 0, 1, 2, 3, 4, 5];
|
|
||||||
let e = vec![0x10, 0x01, 0x23, 0x45];
|
|
||||||
let h = hex_prefix_encode(&v, false);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
|
|
||||||
let v = vec![0, 1, 2, 3, 4, 5];
|
|
||||||
let e = vec![0x00, 0x01, 0x23, 0x45];
|
|
||||||
let h = hex_prefix_encode(&v, false);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
|
|
||||||
let v = vec![0, 1, 2, 3, 4, 5];
|
|
||||||
let e = vec![0x20, 0x01, 0x23, 0x45];
|
|
||||||
let h = hex_prefix_encode(&v, true);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
|
|
||||||
let v = vec![1, 2, 3, 4, 5];
|
|
||||||
let e = vec![0x31, 0x23, 0x45];
|
|
||||||
let h = hex_prefix_encode(&v, true);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
|
|
||||||
let v = vec![1, 2, 3, 4];
|
|
||||||
let e = vec![0x00, 0x12, 0x34];
|
|
||||||
let h = hex_prefix_encode(&v, false);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
|
|
||||||
let v = vec![4, 1];
|
|
||||||
let e = vec![0x20, 0x41];
|
|
||||||
let h = hex_prefix_encode(&v, true);
|
|
||||||
assert_eq!(h, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use std::str::FromStr;
|
use super::{trie_root, shared_prefix_len, hex_prefix_encode};
|
||||||
use hash::H256;
|
|
||||||
use super::trie_root;
|
#[test]
|
||||||
|
fn test_hex_prefix_encode() {
|
||||||
|
let v = vec![0, 0, 1, 2, 3, 4, 5];
|
||||||
|
let e = vec![0x10, 0x01, 0x23, 0x45];
|
||||||
|
let h = hex_prefix_encode(&v, false);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
|
||||||
|
let v = vec![0, 1, 2, 3, 4, 5];
|
||||||
|
let e = vec![0x00, 0x01, 0x23, 0x45];
|
||||||
|
let h = hex_prefix_encode(&v, false);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
|
||||||
|
let v = vec![0, 1, 2, 3, 4, 5];
|
||||||
|
let e = vec![0x20, 0x01, 0x23, 0x45];
|
||||||
|
let h = hex_prefix_encode(&v, true);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
|
||||||
|
let v = vec![1, 2, 3, 4, 5];
|
||||||
|
let e = vec![0x31, 0x23, 0x45];
|
||||||
|
let h = hex_prefix_encode(&v, true);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
|
||||||
|
let v = vec![1, 2, 3, 4];
|
||||||
|
let e = vec![0x00, 0x12, 0x34];
|
||||||
|
let h = hex_prefix_encode(&v, false);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
|
||||||
|
let v = vec![4, 1];
|
||||||
|
let e = vec![0x20, 0x41];
|
||||||
|
let h = hex_prefix_encode(&v, true);
|
||||||
|
assert_eq!(h, e);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn simple_test() {
|
fn simple_test() {
|
||||||
assert_eq!(trie_root(vec![
|
assert_eq!(trie_root(vec![
|
||||||
(b"A".to_vec(), b"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa".to_vec())
|
(b"A".to_vec(), b"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa".to_vec())
|
||||||
]), H256::from_str("d23786fb4a010da3ce639d66d5e904a11dbc02746d1ce25029e53290cabf28ab").unwrap());
|
]), "d23786fb4a010da3ce639d66d5e904a11dbc02746d1ce25029e53290cabf28ab".parse().unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@ -348,4 +348,24 @@ mod tests {
|
|||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_shared_prefix() {
|
||||||
|
let a = vec![1,2,3,4,5,6];
|
||||||
|
let b = vec![4,2,3,4,5,6];
|
||||||
|
assert_eq!(shared_prefix_len(&a, &b), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_shared_prefix2() {
|
||||||
|
let a = vec![1,2,3,3,5];
|
||||||
|
let b = vec![1,2,3];
|
||||||
|
assert_eq!(shared_prefix_len(&a, &b), 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_shared_prefix3() {
|
||||||
|
let a = vec![1,2,3,4,5,6];
|
||||||
|
let b = vec![1,2,3,4,5,6];
|
||||||
|
assert_eq!(shared_prefix_len(&a, &b), 6);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user