Struct ckb_sync::Synchronizer[][src]

pub struct Synchronizer {
    pub shared: Arc<SyncShared>,
    // some fields omitted
}
Expand description

Sync protocol handle

Fields

shared: Arc<SyncShared>

Sync shared state

Implementations

impl Synchronizer[src]

pub fn new(chain: ChainController, shared: Arc<SyncShared>) -> Synchronizer[src]

Init sync protocol handle

This is a runtime sync protocol shared state, and any relay messages will be processed and forwarded by it

pub fn shared(&self) -> &Arc<SyncShared>[src]

Get shared state

pub fn peers(&self) -> &Peers[src]

Get peers info

pub fn process_new_block(&self, block: BlockView) -> Result<bool, AnyError>[src]

Process a new block sync from other peer

pub fn get_blocks_to_fetch(
    &self,
    peer: PeerIndex,
    ibd: IBDState
) -> Option<Vec<Vec<Byte32>>>
[src]

Get blocks to fetch

pub fn eviction(&self, nc: &dyn CKBProtocolContext)[src]

Regularly check and eject some nodes that do not respond in time

Trait Implementations

impl CKBProtocolHandler for Synchronizer[src]

fn init(&mut self, nc: Arc<dyn CKBProtocolContext + Sync>)[src]

Init action on service run

fn received(
    &mut self,
    nc: Arc<dyn CKBProtocolContext + Sync>,
    peer_index: PeerIndex,
    data: Bytes
)
[src]

Called when the corresponding protocol message is received

fn connected(
    &mut self,
    nc: Arc<dyn CKBProtocolContext + Sync>,
    peer_index: PeerIndex,
    _version: &str
)
[src]

Called when opening protocol

fn disconnected(
    &mut self,
    _nc: Arc<dyn CKBProtocolContext + Sync>,
    peer_index: PeerIndex
)
[src]

Called when closing protocol

fn notify(&mut self, nc: Arc<dyn CKBProtocolContext + Sync>, token: u64)[src]

Called when the Service receives the notify task

fn poll(
    &mut self,
    _nc: Arc<dyn CKBProtocolContext + 'static + Sync>
) -> Poll<Option<()>>
[src]

Behave like Stream::poll

impl Clone for Synchronizer[src]

fn clone(&self) -> Synchronizer[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> AsAny for T where
    T: Any

pub fn as_any(&self) -> &(dyn Any + 'static)

TODO(doc): @quake

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> Pointable for T

pub const ALIGN: usize

The alignment of pointer.

type Init = T

The type for initializers.

pub unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more

pub unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more

pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more

pub unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

Creates owned data from borrowed data, usually by cloning. Read more

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 

pub fn vzip(self) -> V

impl<T> Erased for T