1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
use std::ops::{Deref, DerefMut};
use bitcoin_hashes::sha256;
use commit_verify::{commit_encode, ConsensusCommit};
use strict_encoding::MediumVec;
pub type ChunkId = sha256::Hash;
#[derive(Clone, Ord, PartialOrd, Eq, PartialEq, Hash, Debug, Default, From, Display)]
#[derive(NetworkEncode, NetworkDecode)]
#[display("<chunk>")]
pub struct Chunk(MediumVec<u8>);
impl Deref for Chunk {
type Target = MediumVec<u8>;
fn deref(&self) -> &Self::Target { &self.0 }
}
impl DerefMut for Chunk {
fn deref_mut(&mut self) -> &mut Self::Target { &mut self.0 }
}
impl AsRef<[u8]> for Chunk {
fn as_ref(&self) -> &[u8] { self.0.as_ref() }
}
impl TryFrom<&[u8]> for Chunk {
type Error = strict_encoding::Error;
fn try_from(slice: &[u8]) -> Result<Self, Self::Error> {
MediumVec::try_from(slice.to_vec()).map(Self)
}
}
impl commit_encode::Strategy for Chunk {
type Strategy = commit_encode::strategies::UsingStrict;
}
impl ConsensusCommit for Chunk {
type Commitment = ChunkId;
}
impl Chunk {
pub fn chunk_id(&self) -> ChunkId { self.consensus_commit() }
}