pub struct Multihash<S: Size> { /* 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 tiny_multihash::{Multihash, U64};
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::<U64>::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<S: Size> Multihash<S>
impl<S: Size> Multihash<S>
Sourcepub fn wrap(code: u64, input_digest: &[u8]) -> Result<Self, Error>
pub 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.
Trait Implementations§
impl<S: Size> Copy for Multihash<S>
impl<S: Eq + Size> Eq for Multihash<S>
impl<S: Size> StructuralPartialEq for Multihash<S>
Auto Trait Implementations§
impl<S> Freeze for Multihash<S>
impl<S> RefUnwindSafe for Multihash<S>
impl<S> Send for Multihash<S>
impl<S> Sync for Multihash<S>
impl<S> Unpin for Multihash<S>
impl<S> UnwindSafe for Multihash<S>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more