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§
source§impl<const S: usize> Multihash<S>
impl<const S: usize> Multihash<S>
sourcepub const fn wrap(code: u64, input_digest: &[u8]) -> Result<Self, Error>
pub const fn wrap(code: u64, input_digest: &[u8]) -> Result<Self, Error>
Wraps the digest in a multihash.
sourcepub fn read<R: Read>(r: R) -> Result<Self, Error>where
Self: Sized,
pub fn read<R: Read>(r: R) -> Result<Self, Error>where
Self: Sized,
Reads a multihash from a byte stream.
sourcepub fn from_bytes(bytes: &[u8]) -> Result<Self, Error>where
Self: Sized,
pub fn from_bytes(bytes: &[u8]) -> Result<Self, Error>where
Self: Sized,
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.
sourcepub fn write<W: Write>(&self, w: W) -> Result<usize, Error>
pub fn write<W: Write>(&self, w: W) -> Result<usize, Error>
Writes a multihash to a byte stream, returning the written size.
sourcepub fn encoded_len(&self) -> usize
pub fn encoded_len(&self) -> usize
Returns the length in bytes needed to encode this multihash into bytes.
sourcepub fn truncate(&self, size: u8) -> Self
pub fn truncate(&self, size: u8) -> Self
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.
Trait Implementations§
source§impl<const S: usize> Ord for Multihash<S>
impl<const S: usize> Ord for Multihash<S>
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl<const A: usize, const B: usize> PartialEq<Multihash<B>> for Multihash<A>
impl<const A: usize, const B: usize> PartialEq<Multihash<B>> for Multihash<A>
source§impl<const S: usize> PartialOrd for Multihash<S>
impl<const S: usize> PartialOrd for Multihash<S>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more