2019-04-16 02:29:39 +00:00
|
|
|
use super::*;
|
2019-09-04 03:03:44 +00:00
|
|
|
use ethereum_types::{H256, U128, U256};
|
2019-04-16 02:29:39 +00:00
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn int_to_hash256(int: u64) -> Hash256 {
|
|
|
|
let mut bytes = [0; HASHSIZE];
|
|
|
|
bytes[0..8].copy_from_slice(&int.to_le_bytes());
|
|
|
|
Hash256::from_slice(&bytes)
|
|
|
|
}
|
|
|
|
|
2019-04-16 02:29:39 +00:00
|
|
|
macro_rules! impl_for_bitsize {
|
|
|
|
($type: ident, $bit_size: expr) => {
|
|
|
|
impl TreeHash for $type {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
|
|
|
TreeHashType::Basic
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
2019-04-17 01:18:00 +00:00
|
|
|
self.to_le_bytes().to_vec()
|
2019-04-16 02:29:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
HASHSIZE / ($bit_size / 8)
|
|
|
|
}
|
|
|
|
|
2019-04-29 04:04:52 +00:00
|
|
|
#[allow(clippy::cast_lossless)]
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
int_to_hash256(*self as u64)
|
2019-04-16 02:29:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
impl_for_bitsize!(u8, 8);
|
|
|
|
impl_for_bitsize!(u16, 16);
|
|
|
|
impl_for_bitsize!(u32, 32);
|
|
|
|
impl_for_bitsize!(u64, 64);
|
|
|
|
impl_for_bitsize!(usize, 64);
|
2019-04-17 01:18:00 +00:00
|
|
|
|
|
|
|
impl TreeHash for bool {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
|
|
|
TreeHashType::Basic
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
|
|
|
(*self as u8).tree_hash_packed_encoding()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
u8::tree_hash_packing_factor()
|
|
|
|
}
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
int_to_hash256(*self as u64)
|
2019-04-17 01:18:00 +00:00
|
|
|
}
|
|
|
|
}
|
2019-04-16 02:29:39 +00:00
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
/// Only valid for byte types less than 32 bytes.
|
|
|
|
macro_rules! impl_for_lt_32byte_u8_array {
|
2019-05-15 01:48:09 +00:00
|
|
|
($len: expr) => {
|
|
|
|
impl TreeHash for [u8; $len] {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
|
|
|
TreeHashType::Vector
|
|
|
|
}
|
2019-04-16 04:14:38 +00:00
|
|
|
|
2019-05-15 01:48:09 +00:00
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
|
|
|
unreachable!("bytesN should never be packed.")
|
|
|
|
}
|
2019-04-16 04:14:38 +00:00
|
|
|
|
2019-05-15 01:48:09 +00:00
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
unreachable!("bytesN should never be packed.")
|
|
|
|
}
|
2019-04-16 04:14:38 +00:00
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
let mut result = [0; 32];
|
|
|
|
result[0..$len].copy_from_slice(&self[..]);
|
|
|
|
Hash256::from_slice(&result)
|
2019-05-15 01:48:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2019-04-16 04:14:38 +00:00
|
|
|
}
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
impl_for_lt_32byte_u8_array!(4);
|
|
|
|
impl_for_lt_32byte_u8_array!(32);
|
2019-05-15 01:48:09 +00:00
|
|
|
|
2019-09-04 03:03:44 +00:00
|
|
|
impl TreeHash for U128 {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
|
|
|
TreeHashType::Basic
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
|
|
|
let mut result = vec![0; 16];
|
|
|
|
self.to_little_endian(&mut result);
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
2
|
|
|
|
}
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
let mut result = [0; HASHSIZE];
|
|
|
|
self.to_little_endian(&mut result[0..16]);
|
|
|
|
Hash256::from_slice(&result)
|
2019-09-04 03:03:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl TreeHash for U256 {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
|
|
|
TreeHashType::Basic
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
|
|
|
let mut result = vec![0; 32];
|
|
|
|
self.to_little_endian(&mut result);
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
1
|
|
|
|
}
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
let mut result = [0; 32];
|
|
|
|
self.to_little_endian(&mut result[..]);
|
|
|
|
Hash256::from_slice(&result)
|
2019-09-04 03:03:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-16 02:29:39 +00:00
|
|
|
impl TreeHash for H256 {
|
|
|
|
fn tree_hash_type() -> TreeHashType {
|
2019-04-17 00:57:36 +00:00
|
|
|
TreeHashType::Vector
|
2019-04-16 02:29:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
2019-04-17 01:18:00 +00:00
|
|
|
self.as_bytes().to_vec()
|
2019-04-16 02:29:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
|
|
1
|
|
|
|
}
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
fn tree_hash_root(&self) -> Hash256 {
|
|
|
|
*self
|
2019-04-16 02:29:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-16 04:14:38 +00:00
|
|
|
#[cfg(test)]
|
|
|
|
mod test {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn bool() {
|
|
|
|
let mut true_bytes: Vec<u8> = vec![1];
|
|
|
|
true_bytes.append(&mut vec![0; 31]);
|
|
|
|
|
|
|
|
let false_bytes: Vec<u8> = vec![0; 32];
|
|
|
|
|
2020-03-04 21:07:27 +00:00
|
|
|
assert_eq!(true.tree_hash_root().as_bytes(), true_bytes.as_slice());
|
|
|
|
assert_eq!(false.tree_hash_root().as_bytes(), false_bytes.as_slice());
|
2019-04-16 04:14:38 +00:00
|
|
|
}
|
|
|
|
|
2019-08-08 01:39:47 +00:00
|
|
|
#[test]
|
|
|
|
fn int_to_bytes() {
|
2020-03-04 21:07:27 +00:00
|
|
|
assert_eq!(int_to_hash256(0).as_bytes(), &[0; 32]);
|
2019-08-08 01:39:47 +00:00
|
|
|
assert_eq!(
|
2020-03-04 21:07:27 +00:00
|
|
|
int_to_hash256(1).as_bytes(),
|
2019-08-08 01:39:47 +00:00
|
|
|
&[
|
|
|
|
1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0
|
|
|
|
]
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2020-03-04 21:07:27 +00:00
|
|
|
int_to_hash256(u64::max_value()).as_bytes(),
|
2019-08-08 01:39:47 +00:00
|
|
|
&[
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
2019-04-16 04:14:38 +00:00
|
|
|
}
|