Struct cfxcore::sync::SynchronizationGraphInner
source · pub struct SynchronizationGraphInner {Show 13 fields
pub arena: Slab<SynchronizationGraphNode>,
pub hash_to_arena_indices: HashMap<H256, usize>,
pub data_man: Arc<BlockDataManager>,
pub pow_config: ProofOfWorkConfig,
pub pow: Arc<PowComputer>,
pub config: SyncGraphConfig,
pub not_ready_blocks_frontier: UnreadyBlockFrontier,
pub pos_not_ready_blocks_frontier: HashSet<usize>,
pub old_era_blocks_frontier: VecDeque<usize>,
pub old_era_blocks_frontier_set: HashSet<usize>,
pub locked_for_catchup: bool,
pub block_to_fill_set: HashSet<H256>,
pub pos_verifier: Arc<PosVerifier>,
/* private fields */
}
Fields§
§arena: Slab<SynchronizationGraphNode>
§hash_to_arena_indices: HashMap<H256, usize>
§data_man: Arc<BlockDataManager>
§pow_config: ProofOfWorkConfig
§pow: Arc<PowComputer>
§config: SyncGraphConfig
§not_ready_blocks_frontier: UnreadyBlockFrontier
The indices of blocks whose graph_status is not GRAPH_READY.
It may consider not header-graph-ready in phases
CatchUpRecoverBlockHeaderFromDB
and CatchUpSyncBlockHeader
.
Or, it may consider not block-graph-ready in phases
CatchUpRecoverBlockFromDB
, CatchUpSyncBlock
, and Normal
.
pos_not_ready_blocks_frontier: HashSet<usize>
This includes the blocks whose parent and referees are all ready, and only pos_reference has not been ready (pos_reference not committed or its pivot decision is not ready).
old_era_blocks_frontier: VecDeque<usize>
§old_era_blocks_frontier_set: HashSet<usize>
§locked_for_catchup: bool
Set to true
in CatchUpCheckpointPhase
and
CatchUpFillBlockBodyPhase
so that sync graph and consensus graph
remain unchanged for consistency.
block_to_fill_set: HashSet<H256>
The set of blocks that we need to download block bodies in
CatchUpFillBlockBodyPhase
.
pos_verifier: Arc<PosVerifier>
Implementations§
source§impl SynchronizationGraphInner
impl SynchronizationGraphInner
pub fn with_genesis_block( genesis_header: Arc<BlockHeader>, pow_config: ProofOfWorkConfig, pow: Arc<PowComputer>, config: SyncGraphConfig, data_man: Arc<BlockDataManager>, machine: Arc<Machine>, pos_verifier: Arc<PosVerifier> ) -> Self
pub fn get_genesis_hash_and_height_in_current_era(&self) -> (H256, u64)
pub fn get_stable_hash_and_height_in_current_era(&self) -> (H256, u64)
pub fn insert_invalid(&mut self, header: Arc<BlockHeader>) -> usize
sourcepub fn insert(&mut self, header: Arc<BlockHeader>) -> usize
pub fn insert(&mut self, header: Arc<BlockHeader>) -> usize
Return the index of the inserted block.
Trait Implementations§
source§impl MallocSizeOf for SynchronizationGraphInner
impl MallocSizeOf for SynchronizationGraphInner
source§fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize
fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize
Measure the heap usage of all descendant heap-allocated structures, but
not the space taken up by the value itself.
Auto Trait Implementations§
impl !RefUnwindSafe for SynchronizationGraphInner
impl Send for SynchronizationGraphInner
impl Sync for SynchronizationGraphInner
impl Unpin for SynchronizationGraphInner
impl !UnwindSafe for SynchronizationGraphInner
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
§impl<T> Conv for T
impl<T> Conv for T
source§impl<T> DAG for Twhere
T: TreeGraph,
impl<T> DAG for Twhere
T: TreeGraph,
fn predecessor_edges( &self, node_index: <T as Graph>::NodeIndex ) -> Vec<<T as Graph>::NodeIndex>
fn topological_sort_with_order_indicator<OrderIndicator, FOrd, Set>( &self, index_set: Set, order_indicator: FOrd ) -> Vec<Self::NodeIndex>
fn topological_sort<Set>(&self, index_set: Set) -> Vec<Self::NodeIndex>
source§impl<T> ElementSatisfy<ElementNoConstrain> for T
impl<T> ElementSatisfy<ElementNoConstrain> for T
fn to_constrain_object(&self) -> &ElementNoConstrain
fn to_constrain_object_mut(&mut self) -> &mut ElementNoConstrain
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
Causes
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
Causes
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
Causes
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
Causes
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
Causes
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
Causes
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
Causes
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
Causes
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
Formats each item in a sequence. Read more
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>
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
Borrows
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
Mutably borrows
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> RichDAG for Twhere
T: RichTreeGraph + DAG,
impl<T> RichDAG for Twhere
T: RichTreeGraph + DAG,
fn successor_edges( &self, node_index: <T as Graph>::NodeIndex ) -> Vec<<T as Graph>::NodeIndex>
fn get_future_with_stop_condition<FStop, Set, Iter>( &self, index_set: Iter, stop_condition: FStop ) -> Set
fn get_future<Set, Iter>(&self, index_set: Iter) -> Set
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls
.tap_deref()
only in debug builds, and is erased in release
builds.