Tidy ssz lib; add comments, remove dup func.
This commit is contained in:
parent
3d3b1fcdda
commit
176c6f5cb6
@ -4,6 +4,11 @@ pub trait Encodable {
|
|||||||
fn ssz_append(&self, s: &mut SszStream);
|
fn ssz_append(&self, s: &mut SszStream);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Provides a buffer for appending ssz-encodable values.
|
||||||
|
///
|
||||||
|
/// Use the `append()` fn to add a value to a list, then use
|
||||||
|
/// the `drain()` method to consume the struct and return the
|
||||||
|
/// ssz encoded bytes.
|
||||||
pub struct SszStream {
|
pub struct SszStream {
|
||||||
buffer: Vec<u8>
|
buffer: Vec<u8>
|
||||||
}
|
}
|
||||||
@ -24,14 +29,21 @@ impl SszStream {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn extend_buffer(&mut self, vec: &Vec<u8>) {
|
/// Append some ssz encoded bytes to the steam.
|
||||||
|
///
|
||||||
|
/// The length of the supplied bytes will be concatenated
|
||||||
|
/// to the stream before the supplied bytes.
|
||||||
|
pub fn append_encoded_val(&mut self, vec: &Vec<u8>) {
|
||||||
self.buffer.extend_from_slice(
|
self.buffer.extend_from_slice(
|
||||||
&encode_length(vec.len(),
|
&encode_length(vec.len(),
|
||||||
LENGTH_BYTES));
|
LENGTH_BYTES));
|
||||||
self.buffer.extend_from_slice(&vec);
|
self.buffer.extend_from_slice(&vec);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Append some vector (list) of encoded values to the stream.
|
/// Append some vector (list) of encodable values to the stream.
|
||||||
|
///
|
||||||
|
/// The length of the list will be concatenated to the stream, then
|
||||||
|
/// each item in the vector will be encoded and concatenated.
|
||||||
pub fn append_vec<E>(&mut self, vec: &Vec<E>)
|
pub fn append_vec<E>(&mut self, vec: &Vec<E>)
|
||||||
where E: Encodable
|
where E: Encodable
|
||||||
{
|
{
|
||||||
@ -41,19 +53,16 @@ impl SszStream {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Append some array (list) of encoded values to the stream.
|
|
||||||
pub fn append_encoded_array(&mut self, a: &mut [u8]) {
|
|
||||||
let len = a.len();
|
|
||||||
self.buffer.append(&mut encode_length(len, LENGTH_BYTES));
|
|
||||||
self.buffer.extend_from_slice(&a[0..len]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Consume the stream and return the underlying bytes.
|
/// Consume the stream and return the underlying bytes.
|
||||||
pub fn drain(self) -> Vec<u8> {
|
pub fn drain(self) -> Vec<u8> {
|
||||||
self.buffer
|
self.buffer
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Encode some length into a ssz size prefix.
|
||||||
|
///
|
||||||
|
/// The ssz size prefix is 4 bytes, which is treated as a continuious
|
||||||
|
/// 32bit big-endian integer.
|
||||||
pub fn encode_length(len: usize, length_bytes: usize) -> Vec<u8> {
|
pub fn encode_length(len: usize, length_bytes: usize) -> Vec<u8> {
|
||||||
assert!(length_bytes > 0); // For sanity
|
assert!(length_bytes > 0); // For sanity
|
||||||
assert!((len as usize) < 2usize.pow(length_bytes as u32 * 8));
|
assert!((len as usize) < 2usize.pow(length_bytes as u32 * 8));
|
||||||
@ -108,7 +117,7 @@ mod tests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_serialization() {
|
fn test_encode_struct() {
|
||||||
pub struct TestStruct {
|
pub struct TestStruct {
|
||||||
pub one: u32,
|
pub one: u32,
|
||||||
pub two: H256,
|
pub two: H256,
|
||||||
|
@ -40,7 +40,7 @@ impl_decodable_for_uint!(u16, 16 / 8);
|
|||||||
|
|
||||||
impl Encodable for u8 {
|
impl Encodable for u8 {
|
||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
s.extend_buffer(&mut vec![*self]);
|
s.append_encoded_val(&mut vec![*self]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,7 +48,7 @@ impl Encodable for u16 {
|
|||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
let mut buf = BytesMut::with_capacity(16/8);
|
let mut buf = BytesMut::with_capacity(16/8);
|
||||||
buf.put_u16_be(*self);
|
buf.put_u16_be(*self);
|
||||||
s.extend_buffer(&buf.to_vec());
|
s.append_encoded_val(&buf.to_vec());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +56,7 @@ impl Encodable for u32 {
|
|||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
let mut buf = BytesMut::with_capacity(32/8);
|
let mut buf = BytesMut::with_capacity(32/8);
|
||||||
buf.put_u32_be(*self);
|
buf.put_u32_be(*self);
|
||||||
s.extend_buffer(&buf.to_vec());
|
s.append_encoded_val(&buf.to_vec());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,13 +64,13 @@ impl Encodable for u64 {
|
|||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
let mut buf = BytesMut::with_capacity(64/8);
|
let mut buf = BytesMut::with_capacity(64/8);
|
||||||
buf.put_u64_be(*self);
|
buf.put_u64_be(*self);
|
||||||
s.extend_buffer(&buf.to_vec());
|
s.append_encoded_val(&buf.to_vec());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Encodable for H256 {
|
impl Encodable for H256 {
|
||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
s.extend_buffer(&self.to_vec());
|
s.append_encoded_val(&self.to_vec());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,6 +78,6 @@ impl Encodable for U256 {
|
|||||||
fn ssz_append(&self, s: &mut SszStream) {
|
fn ssz_append(&self, s: &mut SszStream) {
|
||||||
let mut a = [0; 32];
|
let mut a = [0; 32];
|
||||||
self.to_big_endian(&mut a);
|
self.to_big_endian(&mut a);
|
||||||
s.append_encoded_array(&mut a);
|
s.append_encoded_val(&a.to_vec());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user