Struct fuel_core_txpool::service::Task
source · pub struct Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> { /* private fields */ }
Trait Implementations§
source§impl<P2P, ViewProvider, View, GasPriceProvider, ConsensusProvider, MP> RunnableService for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>where
P2P: PeerToPeer<GossipedTransaction = TransactionGossipData>,
ViewProvider: AtomicView<View = View>,
View: TxPoolDb,
GasPriceProvider: GasPriceProviderConstraint + Send + Sync,
ConsensusProvider: ConsensusParametersProvider + Send + Sync,
MP: MemoryPool + Send + Sync,
impl<P2P, ViewProvider, View, GasPriceProvider, ConsensusProvider, MP> RunnableService for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>where
P2P: PeerToPeer<GossipedTransaction = TransactionGossipData>,
ViewProvider: AtomicView<View = View>,
View: TxPoolDb,
GasPriceProvider: GasPriceProviderConstraint + Send + Sync,
ConsensusProvider: ConsensusParametersProvider + Send + Sync,
MP: MemoryPool + Send + Sync,
source§const NAME: &'static str = "TxPool"
const NAME: &'static str = "TxPool"
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.
§type Task = Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
type Task = Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
The initialized runnable task type.
§type TaskParams = ()
type TaskParams = ()
Optional parameters used to when initializing into task.
A cloned instance of the shared data
source§fn into_task<'life0, 'async_trait>(
self,
_: &'life0 StateWatcher,
__arg2: Self::TaskParams,
) -> Pin<Box<dyn Future<Output = Result<Self::Task>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn into_task<'life0, 'async_trait>(
self,
_: &'life0 StateWatcher,
__arg2: Self::TaskParams,
) -> Pin<Box<dyn Future<Output = Result<Self::Task>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Converts the service into a runnable task before the main run loop. Read more
source§impl<P2P, ViewProvider, View, GasPriceProvider, ConsensusProvider, MP> RunnableTask for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>where
P2P: PeerToPeer<GossipedTransaction = TransactionGossipData>,
ViewProvider: AtomicView<View = View>,
View: TxPoolDb,
GasPriceProvider: GasPriceProviderConstraint + Send + Sync,
ConsensusProvider: ConsensusParametersProvider + Send + Sync,
MP: MemoryPool + Send + Sync,
impl<P2P, ViewProvider, View, GasPriceProvider, ConsensusProvider, MP> RunnableTask for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>where
P2P: PeerToPeer<GossipedTransaction = TransactionGossipData>,
ViewProvider: AtomicView<View = View>,
View: TxPoolDb,
GasPriceProvider: GasPriceProviderConstraint + Send + Sync,
ConsensusProvider: ConsensusParametersProvider + Send + Sync,
MP: MemoryPool + Send + Sync,
source§fn run<'life0, 'life1, 'async_trait>(
&'life0 mut self,
watcher: &'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,
watcher: &'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<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> Freeze for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
impl<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> !RefUnwindSafe for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
impl<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> Send for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
impl<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> Sync for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
impl<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> Unpin for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
impl<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP> !UnwindSafe for Task<P2P, ViewProvider, GasPriceProvider, ConsensusProvider, MP>
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
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> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<S> IteratorOverTable for S
impl<S> IteratorOverTable for S
source§fn iter_all<M>(
&self,
direction: Option<IterDirection>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>where
M: Mappable,
Self: IterableTable<M>,
fn iter_all<M>(
&self,
direction: Option<IterDirection>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>where
M: Mappable,
Self: IterableTable<M>,
Returns an iterator over the all entries in the table.
source§fn iter_all_by_prefix<M, P>(
&self,
prefix: Option<P>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>
fn iter_all_by_prefix<M, P>( &self, prefix: Option<P>, ) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>
Returns an iterator over the all entries in the table with the specified prefix.
source§fn iter_all_by_start<M>(
&self,
start: Option<&<M as Mappable>::Key>,
direction: Option<IterDirection>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>where
M: Mappable,
Self: IterableTable<M>,
fn iter_all_by_start<M>(
&self,
start: Option<&<M as Mappable>::Key>,
direction: Option<IterDirection>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>where
M: Mappable,
Self: IterableTable<M>,
Returns an iterator over the all entries in the table after a specific start key.
source§fn iter_all_filtered<M, P>(
&self,
prefix: Option<P>,
start: Option<&<M as Mappable>::Key>,
direction: Option<IterDirection>,
) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>
fn iter_all_filtered<M, P>( &self, prefix: Option<P>, start: Option<&<M as Mappable>::Key>, direction: Option<IterDirection>, ) -> BoxedIter<'_, Result<(<M as Mappable>::OwnedKey, <M as Mappable>::OwnedValue), Error>>
Returns an iterator over the all entries in the table with a prefix after a specific start key.