[][src]Trait reference_trie::NodeCodec

pub trait NodeCodec<H> where
    H: Hasher
{ type Error: Error; fn hashed_null_node() -> <H as Hasher>::Out;
fn decode(data: &[u8]) -> Result<Node, Self::Error>;
fn try_decode_hash(data: &[u8]) -> Option<<H as Hasher>::Out>;
fn is_empty_node(data: &[u8]) -> bool;
fn empty_node() -> Vec<u8>;
fn leaf_node(partial: &[u8], value: &[u8]) -> Vec<u8>;
fn ext_node(
        partial: &[u8],
        child_ref: ChildReference<<H as Hasher>::Out>
    ) -> Vec<u8>;
fn branch_node<I>(
        children: I,
        value: Option<ElasticArray128<u8>>
    ) -> Vec<u8>
    where
        I: IntoIterator<Item = Option<ChildReference<<H as Hasher>::Out>>> + Iterator<Item = Option<ChildReference<<H as Hasher>::Out>>>
; }

Trait for trie node encoding/decoding

Associated Types

type Error: Error

Codec error type

Loading content...

Required methods

fn hashed_null_node() -> <H as Hasher>::Out

Get the hashed null node.

fn decode(data: &[u8]) -> Result<Node, Self::Error>

Decode bytes to a Node. Returns Self::E on failure.

fn try_decode_hash(data: &[u8]) -> Option<<H as Hasher>::Out>

Decode bytes to the Hashers output type. Returns None on failure.

fn is_empty_node(data: &[u8]) -> bool

Check if the provided bytes correspond to the codecs "empty" node.

fn empty_node() -> Vec<u8>

Returns an empty node

fn leaf_node(partial: &[u8], value: &[u8]) -> Vec<u8>

Returns an encoded leaf node

fn ext_node(
    partial: &[u8],
    child_ref: ChildReference<<H as Hasher>::Out>
) -> Vec<u8>

Returns an encoded extension node

fn branch_node<I>(children: I, value: Option<ElasticArray128<u8>>) -> Vec<u8> where
    I: IntoIterator<Item = Option<ChildReference<<H as Hasher>::Out>>> + Iterator<Item = Option<ChildReference<<H as Hasher>::Out>>>, 

Returns an encoded branch node. Takes an iterator yielding ChildReference<H::Out> and an optional value

Loading content...

Implementors

impl NodeCodec<KeccakHasher> for ReferenceNodeCodec
[src]

type Error = ReferenceError

Loading content...