lighthouse/beacon_chain/utils/ssz/src/impl_encode.rs

189 lines
5.0 KiB
Rust
Raw Normal View History

2018-09-17 06:54:51 +00:00
extern crate bytes;
use super::{
Encodable,
SszStream
};
use super::ethereum_types::H256;
2018-09-17 06:54:51 +00:00
use self::bytes::{ BytesMut, BufMut };
/*
* Note: there is a "to_bytes" function for integers
* in Rust nightly. When it is in stable, we should
* use it instead.
*/
macro_rules! impl_encodable_for_uint {
2018-09-17 06:54:51 +00:00
($type: ident, $bit_size: expr) => {
impl Encodable for $type {
fn ssz_append(&self, s: &mut SszStream)
{
2018-09-17 06:54:51 +00:00
// Ensure bit size is valid
assert!((0 < $bit_size) &&
($bit_size % 8 == 0) &&
(2_u128.pow($bit_size) > *self as u128));
// Serialize to bytes
let mut buf = BytesMut::with_capacity($bit_size/8);
// Match bit size with encoding
match $bit_size {
8 => buf.put_u8(*self as u8),
16 => buf.put_u16_be(*self as u16),
32 => buf.put_u32_be(*self as u32),
64 => buf.put_u64_be(*self as u64),
_ => { ; }
}
2018-09-17 06:54:51 +00:00
// Append bytes to the SszStream
2018-10-20 20:15:58 +00:00
s.append_encoded_raw(&buf.to_vec());
}
}
}
}
2018-09-17 06:54:51 +00:00
impl_encodable_for_uint!(u8, 8);
impl_encodable_for_uint!(u16, 16);
impl_encodable_for_uint!(u32, 32);
impl_encodable_for_uint!(u64, 64);
impl_encodable_for_uint!(usize, 64);
impl Encodable for H256 {
fn ssz_append(&self, s: &mut SszStream) {
s.append_encoded_raw(&self.to_vec());
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_ssz_encode_h256() {
let h = H256::zero();
let mut ssz = SszStream::new();
ssz.append(&h);
assert_eq!(ssz.drain(), vec![0; 32]);
}
#[test]
fn test_ssz_encode_u8() {
2018-09-17 06:54:51 +00:00
let x: u8 = 0;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0]);
2018-09-17 06:54:51 +00:00
let x: u8 = 1;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![1]);
2018-09-17 06:54:51 +00:00
let x: u8 = 100;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![100]);
2018-09-17 06:54:51 +00:00
let x: u8 = 255;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![255]);
}
#[test]
fn test_ssz_encode_u16() {
let x: u16 = 1;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 1]);
let x: u16 = 100;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 100]);
let x: u16 = 1 << 8;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![1, 0]);
let x: u16 = 65535;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![255, 255]);
}
#[test]
fn test_ssz_encode_u32() {
let x: u32 = 1;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 1]);
let x: u32 = 100;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 100]);
let x: u32 = 1 << 16;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 1, 0, 0]);
let x: u32 = 1 << 24;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![1, 0, 0, 0]);
let x: u32 = !0;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![255, 255, 255, 255]);
}
#[test]
fn test_ssz_encode_u64() {
let x: u64 = 1;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 0, 0, 0, 0, 1]);
let x: u64 = 100;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 0, 0, 0, 0, 100]);
let x: u64 = 1 << 32;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 1, 0, 0, 0, 0]);
let x: u64 = !0;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![255, 255, 255, 255, 255, 255, 255, 255]);
}
2018-09-13 03:02:51 +00:00
#[test]
fn test_ssz_encode_usize() {
let x: usize = 1;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 0, 0, 0, 0, 1]);
2018-09-13 03:02:51 +00:00
let x: usize = 100;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 0, 0, 0, 0, 100]);
2018-09-13 03:02:51 +00:00
let x: usize = 1 << 32;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![0, 0, 0, 1, 0, 0, 0, 0]);
2018-09-13 03:02:51 +00:00
let x: usize = !0;
let mut ssz = SszStream::new();
ssz.append(&x);
2018-09-17 06:54:51 +00:00
assert_eq!(ssz.drain(), vec![255, 255, 255, 255, 255, 255, 255, 255]);
2018-09-13 03:02:51 +00:00
}
}