Struct canonical::Id[][src]

pub struct Id { /* fields omitted */ }
Expand description

This is the Id type, that uniquely identifies slices of bytes, in rust equivalent to &[u8]. As in the case with &[u8] the length is also encoded in the type, making it a kind of a fat-pointer for content adressed byteslices.

The length of the corresponding bytestring is encoed in the first two bytes in big endian.

If the length of the byteslice is less than or equal to 32 bytes, the bytes are stored directly inline in the bytes field.

Proposal: The trailing bytes in an inlined value MUST be set to zero

Implementations

impl Id[src]

pub fn new<T>(t: &T) -> Self where
    T: Canon
[src]

Creates a new Id from a type

pub fn hash(&self) -> IdHash[src]

Returns the computed hash of the value.

Note that this is different from the payload itself in case of an inlined value, that normally does not get hashed.

Useful for giving a well-distributed unique id for all Canon types, for use in hash maps for example.

pub fn payload(&self) -> &[u8; 32][src]

Returns the bytes of the identifier

pub fn into_payload(self) -> [u8; 32][src]

Consumes the Id and returns the payload bytes

pub const fn size(&self) -> usize[src]

Returns the length of the represented data

pub fn reify<T>(&self) -> Result<T, CanonError> where
    T: Canon
[src]

Attempts to reify the Id as an instance of type T

pub fn take_bytes(&self) -> Result<Option<Vec<u8>>, CanonError>[src]

Takes the bytes corresponding to this id out of the underlying store.

If the Id is inlined, this is a no-op and returns Ok(None)

Trait Implementations

impl<'a> Arbitrary<'a> for Id[src]

fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self>[src]

Generate an arbitrary value of Self from the given unstructured data. Read more

fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>[src]

Generate an arbitrary value of Self from the entirety of the given unstructured data. Read more

fn size_hint(depth: usize) -> (usize, Option<usize>)[src]

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more

impl Canon for Id[src]

fn encode(&self, sink: &mut Sink<'_>)[src]

Write the value as bytes to a Sink

fn decode(source: &mut Source<'_>) -> Result<Self, CanonError>[src]

Read the value from bytes in a Source

fn encoded_len(&self) -> usize[src]

Returns the number of bytes needed to encode this value

impl Clone for Id[src]

fn clone(&self) -> Id[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for Id[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl Default for Id[src]

fn default() -> Id[src]

Returns the “default value” for a type. Read more

impl Hash for Id[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl Ord for Id[src]

fn cmp(&self, other: &Id) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl PartialEq<Id> for Id[src]

fn eq(&self, other: &Id) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Id) -> bool[src]

This method tests for !=.

impl PartialOrd<Id> for Id[src]

fn partial_cmp(&self, other: &Id) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Copy for Id[src]

impl Eq for Id[src]

impl StructuralEq for Id[src]

impl StructuralPartialEq for Id[src]

Auto Trait Implementations

impl RefUnwindSafe for Id

impl Send for Id

impl Sync for Id

impl Unpin for Id

impl UnwindSafe for Id

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

Creates owned data from borrowed data, usually by cloning. Read more

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.