Struct bitcoin::util::bip152::HeaderAndShortIds
source · pub struct HeaderAndShortIds {
pub header: BlockHeader,
pub nonce: u64,
pub short_ids: Vec<ShortId>,
pub prefilled_txs: Vec<PrefilledTransaction>,
}
Expand description
A HeaderAndShortIds structure is used to relay a block header, the short transactions IDs used for matching already-available transactions, and a select few transactions which we expect a peer may be missing.
Fields§
§header: BlockHeader
The header of the block being provided.
nonce: u64
A nonce for use in short transaction ID calculations.
short_ids: Vec<ShortId>
The short transaction IDs calculated from the transactions which were not provided explicitly in prefilled_txs.
prefilled_txs: Vec<PrefilledTransaction>
Used to provide the coinbase transaction and a select few which we expect a peer may be missing.
Implementations§
source§impl HeaderAndShortIds
impl HeaderAndShortIds
sourcepub fn from_block(
block: &Block,
nonce: u64,
version: u32,
prefill: &[usize]
) -> Result<HeaderAndShortIds, Error>
pub fn from_block( block: &Block, nonce: u64, version: u32, prefill: &[usize] ) -> Result<HeaderAndShortIds, Error>
Create a new HeaderAndShortIds from a full block.
The version number must be either 1 or 2.
The prefill
slice indicates which transactions should be prefilled in
the block. It should contain the indexes in the block of the txs to
prefill. It must be ordered. 0 should not be included as the
coinbase tx is always prefilled.
Nodes SHOULD NOT use the same nonce across multiple different blocks.
Trait Implementations§
source§impl Clone for HeaderAndShortIds
impl Clone for HeaderAndShortIds
source§fn clone(&self) -> HeaderAndShortIds
fn clone(&self) -> HeaderAndShortIds
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for HeaderAndShortIds
impl Debug for HeaderAndShortIds
source§impl Decodable for HeaderAndShortIds
impl Decodable for HeaderAndShortIds
source§fn consensus_decode_from_finite_reader<R: Read + ?Sized>(
r: &mut R
) -> Result<HeaderAndShortIds, Error>
fn consensus_decode_from_finite_reader<R: Read + ?Sized>( r: &mut R ) -> Result<HeaderAndShortIds, Error>
Self
from a size-limited reader. Read moresource§fn consensus_decode<R: Read + ?Sized>(
r: &mut R
) -> Result<HeaderAndShortIds, Error>
fn consensus_decode<R: Read + ?Sized>( r: &mut R ) -> Result<HeaderAndShortIds, Error>
source§impl Encodable for HeaderAndShortIds
impl Encodable for HeaderAndShortIds
source§impl Hash for HeaderAndShortIds
impl Hash for HeaderAndShortIds
source§impl Ord for HeaderAndShortIds
impl Ord for HeaderAndShortIds
source§fn cmp(&self, other: &HeaderAndShortIds) -> Ordering
fn cmp(&self, other: &HeaderAndShortIds) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere Self: Sized,
source§impl PartialEq<HeaderAndShortIds> for HeaderAndShortIds
impl PartialEq<HeaderAndShortIds> for HeaderAndShortIds
source§fn eq(&self, other: &HeaderAndShortIds) -> bool
fn eq(&self, other: &HeaderAndShortIds) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl PartialOrd<HeaderAndShortIds> for HeaderAndShortIds
impl PartialOrd<HeaderAndShortIds> for HeaderAndShortIds
source§fn partial_cmp(&self, other: &HeaderAndShortIds) -> Option<Ordering>
fn partial_cmp(&self, other: &HeaderAndShortIds) -> Option<Ordering>
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