radix_trie

Trait TrieKey

Source
pub trait TrieKey: PartialEq + Eq {
    // Provided methods
    fn encode_bytes(&self) -> Vec<u8> { ... }
    fn encode(&self) -> Nibblet { ... }
}
Expand description

Trait for types which can be used to key a Radix Trie.

Types that implement this trait should be convertible to a vector of half-bytes (nibbles) such that no two instances of the type convert to the same vector. To protect against faulty behaviour, the trie will panic if it finds two distinct keys of type K which encode to the same Nibblet, so be careful!

If you would like to implement this trait for your own type, you need to implement either encode_bytes or encode. You only need to implement one of the two. If you don’t implement one, your code will panic as soon you use the trie. There is no performance penalty for implementing encode_bytes instead of encode, so it is preferred except in the case where you require half-byte precision.

Many standard types implement this trait already. Integer types are encoded big-endian by default but can be encoded little-endian using the LittleEndian<T> wrapper type.

Provided Methods§

Source

fn encode_bytes(&self) -> Vec<u8>

Encode a value as a vector of bytes.

Source

fn encode(&self) -> Nibblet

Encode a value as a NibbleVec.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl TrieKey for i8

Source§

impl TrieKey for i16

Source§

impl TrieKey for i32

Source§

impl TrieKey for i64

Source§

impl TrieKey for isize

Source§

impl TrieKey for str

Source§

impl TrieKey for u8

Source§

impl TrieKey for u16

Source§

impl TrieKey for u32

Source§

impl TrieKey for u64

Source§

impl TrieKey for usize

Source§

impl TrieKey for String

Source§

impl TrieKey for Vec<i16>

Source§

impl TrieKey for Vec<i32>

Source§

impl TrieKey for Vec<i64>

Source§

impl TrieKey for Vec<isize>

Source§

impl TrieKey for Vec<u8>

Source§

impl TrieKey for Vec<u16>

Source§

impl TrieKey for Vec<u32>

Source§

impl TrieKey for Vec<u64>

Source§

impl TrieKey for Vec<usize>

Source§

impl TrieKey for Path

Source§

impl TrieKey for PathBuf

Source§

impl TrieKey for [u8]

Source§

impl<'a, T: ?Sized + TrieKey> TrieKey for &'a T

Source§

impl<'a, T: ?Sized + TrieKey> TrieKey for &'a mut T

Source§

impl<T> TrieKey for BigEndian<T>
where T: Eq + Copy,

Source§

impl<T> TrieKey for LittleEndian<T>
where T: Eq + Copy,

Implementors§