Struct fuel_core_sync::service::SyncTask
source · pub struct SyncTask<P, E, C>where
P: PeerToPeerPort + Send + Sync + 'static,
E: BlockImporterPort + Send + Sync + 'static,
C: ConsensusPort + Send + Sync + 'static,{ /* private fields */ }
Expand description
Task for syncing heights. Contains import task as a child task.
Trait Implementations§
source§impl<P, E, C> RunnableService for SyncTask<P, E, C>where
P: PeerToPeerPort + Send + Sync + 'static,
E: BlockImporterPort + Send + Sync + 'static,
C: ConsensusPort + Send + Sync + 'static,
impl<P, E, C> RunnableService for SyncTask<P, E, C>where P: PeerToPeerPort + Send + Sync + 'static, E: BlockImporterPort + Send + Sync + 'static, C: ConsensusPort + Send + Sync + 'static,
source§const NAME: &'static str = "fuel-core-sync"
const NAME: &'static str = "fuel-core-sync"
The name of the runnable service, used for namespacing error messages.
Service specific shared data. This is used when you have data that needs to be shared by
one or more tasks. It is the implementors responsibility to ensure cloning this
type is shallow and doesn’t provide a full duplication of data that is meant
to be shared between asynchronous processes.
A cloned instance of the shared data
source§impl<P, E, C> RunnableTask for SyncTask<P, E, C>where
P: PeerToPeerPort + Send + Sync + 'static,
E: BlockImporterPort + Send + Sync + 'static,
C: ConsensusPort + Send + Sync + 'static,
impl<P, E, C> RunnableTask for SyncTask<P, E, C>where P: PeerToPeerPort + Send + Sync + 'static, E: BlockImporterPort + Send + Sync + 'static, C: ConsensusPort + Send + Sync + 'static,
source§fn run<'life0, 'life1, 'async_trait>(
&'life0 mut self,
_: &'life1 mut StateWatcher
) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn run<'life0, 'life1, 'async_trait>( &'life0 mut self, _: &'life1 mut StateWatcher ) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
This function should contain the main business logic of the service task. It will run until
the service either returns false, panics or a stop signal is received.
If the service returns an error, it will be logged and execution will resume.
This is intended to be called only by the
ServiceRunner
. Read moreAuto Trait Implementations§
impl<P, E, C> !RefUnwindSafe for SyncTask<P, E, C>
impl<P, E, C> Send for SyncTask<P, E, C>
impl<P, E, C> Sync for SyncTask<P, E, C>
impl<P, E, C> Unpin for SyncTask<P, E, C>
impl<P, E, C> !UnwindSafe for SyncTask<P, E, C>
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