Struct sc_network_sync::blocks::BlockCollection
source · pub struct BlockCollection<B: BlockT> { /* private fields */ }
Expand description
A collection of blocks being downloaded.
Implementations§
source§impl<B: BlockT> BlockCollection<B>
impl<B: BlockT> BlockCollection<B>
sourcepub fn insert(
&mut self,
start: NumberFor<B>,
blocks: Vec<BlockData<B>>,
who: PeerId
)
pub fn insert( &mut self, start: NumberFor<B>, blocks: Vec<BlockData<B>>, who: PeerId )
Insert a set of blocks into collection.
sourcepub fn needed_blocks(
&mut self,
who: PeerId,
count: u32,
peer_best: NumberFor<B>,
common: NumberFor<B>,
max_parallel: u32,
max_ahead: u32
) -> Option<Range<NumberFor<B>>>
pub fn needed_blocks( &mut self, who: PeerId, count: u32, peer_best: NumberFor<B>, common: NumberFor<B>, max_parallel: u32, max_ahead: u32 ) -> Option<Range<NumberFor<B>>>
Returns a set of block hashes that require a header download. The returned set is marked as being downloaded.
sourcepub fn ready_blocks(&mut self, from: NumberFor<B>) -> Vec<BlockData<B>>
pub fn ready_blocks(&mut self, from: NumberFor<B>) -> Vec<BlockData<B>>
Get a valid chain of blocks ordered in descending order and ready for importing into
the blockchain.
from
is the maximum block number for the start of the range that we are interested in.
The function will return empty Vec if the first block ready is higher than from
.
For each returned block hash clear_queued
must be called at some later stage.
pub fn clear_queued(&mut self, hash: &B::Hash)
pub fn clear_peer_download(&mut self, who: &PeerId)
Trait Implementations§
Auto Trait Implementations§
impl<B> RefUnwindSafe for BlockCollection<B>where <B as Block>::Extrinsic: RefUnwindSafe, <B as Block>::Hash: RefUnwindSafe, <B as Block>::Header: RefUnwindSafe, <<B as Block>::Header as Header>::Number: RefUnwindSafe,
impl<B> Send for BlockCollection<B>
impl<B> Sync for BlockCollection<B>
impl<B> Unpin for BlockCollection<B>where <B as Block>::Hash: Unpin, <<B as Block>::Header as Header>::Number: Unpin,
impl<B> UnwindSafe for BlockCollection<B>where <B as Block>::Extrinsic: RefUnwindSafe, <B as Block>::Hash: UnwindSafe + RefUnwindSafe, <B as Block>::Header: RefUnwindSafe, <<B as Block>::Header as Header>::Number: UnwindSafe + RefUnwindSafe,
Blanket Implementations§
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of
T
. Read moresource§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of
T
.