Struct Multihash
pub struct Multihash<const S: usize> { /* private fields */ }
Expand description
A Multihash instance that only supports the basic functionality and no hashing.
With this Multihash implementation you can operate on Multihashes in a generic way, but no hasher implementation is associated with the code.
§Example
use multihash::Multihash;
const Sha3_256: u64 = 0x16;
let digest_bytes = [
0x16, 0x20, 0x64, 0x4b, 0xcc, 0x7e, 0x56, 0x43, 0x73, 0x04, 0x09, 0x99, 0xaa, 0xc8, 0x9e,
0x76, 0x22, 0xf3, 0xca, 0x71, 0xfb, 0xa1, 0xd9, 0x72, 0xfd, 0x94, 0xa3, 0x1c, 0x3b, 0xfb,
0xf2, 0x4e, 0x39, 0x38,
];
let mh = Multihash::<32>::from_bytes(&digest_bytes).unwrap();
assert_eq!(mh.code(), Sha3_256);
assert_eq!(mh.size(), 32);
assert_eq!(mh.digest(), &digest_bytes[2..]);
Implementations§
§impl<const S: usize> Multihash<S>
impl<const S: usize> Multihash<S>
pub const fn wrap(code: u64, input_digest: &[u8]) -> Result<Multihash<S>, Error>
pub const fn wrap(code: u64, input_digest: &[u8]) -> Result<Multihash<S>, Error>
Wraps the digest in a multihash.
pub fn from_bytes(bytes: &[u8]) -> Result<Multihash<S>, Error>
pub fn from_bytes(bytes: &[u8]) -> Result<Multihash<S>, Error>
Parses a multihash from a bytes.
You need to make sure the passed in bytes have the correct length. The digest length
needs to match the size
value of the multihash.
pub fn write<W>(&self, w: W) -> Result<usize, Error>where
W: Write,
pub fn write<W>(&self, w: W) -> Result<usize, Error>where
W: Write,
Writes a multihash to a byte stream, returning the written size.
pub fn encoded_len(&self) -> usize
pub fn encoded_len(&self) -> usize
Returns the length in bytes needed to encode this multihash into bytes.
pub fn to_bytes(&self) -> Vec<u8> ⓘ
Available on crate feature alloc
only.
pub fn to_bytes(&self) -> Vec<u8> ⓘ
alloc
only.Returns the bytes of a multihash.
pub fn truncate(&self, size: u8) -> Multihash<S>
pub fn truncate(&self, size: u8) -> Multihash<S>
Truncates the multihash to the given size. It’s up to the caller to ensure that the new size is secure (cryptographically) to use.
If the new size is larger than the current size, this method does nothing.
pub fn resize<const R: usize>(&self) -> Result<Multihash<R>, Error>
pub fn resize<const R: usize>(&self) -> Result<Multihash<R>, Error>
Resizes the backing multihash buffer.
This function fails if the hash digest is larger than the target size.
pub fn into_inner(self) -> (u64, [u8; S], u8)
pub fn into_inner(self) -> (u64, [u8; S], u8)
Decomposes struct, useful when needing a Sized
array or moving all the data into another type
It is recommended to use digest()
code()
and size()
for most cases.
Trait Implementations§
§impl<'de, const SIZE: usize> Deserialize<'de> for Multihash<SIZE>
impl<'de, const SIZE: usize> Deserialize<'de> for Multihash<SIZE>
§fn deserialize<D>(
deserializer: D,
) -> Result<Multihash<SIZE>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>(
deserializer: D,
) -> Result<Multihash<SIZE>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
§impl<const S: usize> Ord for Multihash<S>
impl<const S: usize> Ord for Multihash<S>
§impl<const S: usize> PartialOrd for Multihash<S>
impl<const S: usize> PartialOrd for Multihash<S>
§impl<const SIZE: usize> Serialize for Multihash<SIZE>
impl<const SIZE: usize> Serialize for Multihash<SIZE>
§fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
impl<const S: usize> Copy for Multihash<S>
impl<const S: usize> Eq for Multihash<S>
Auto Trait Implementations§
impl<const S: usize> Freeze for Multihash<S>
impl<const S: usize> RefUnwindSafe for Multihash<S>
impl<const S: usize> Send for Multihash<S>
impl<const S: usize> Sync for Multihash<S>
impl<const S: usize> Unpin for Multihash<S>
impl<const S: usize> UnwindSafe for Multihash<S>
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more