pub struct ChannelProvider<P>{ /* private fields */ }
Expand description
The ChannelProvider stage is a mux between the ChannelBank and ChannelAssembler stages.
Rules: When Holocene is not active, the ChannelBank is used. When Holocene is active, the ChannelAssembler is used.
Implementations§
Source§impl<P> ChannelProvider<P>
impl<P> ChannelProvider<P>
Sourcepub const fn new(cfg: Arc<RollupConfig>, prev: P) -> ChannelProvider<P>
pub const fn new(cfg: Arc<RollupConfig>, prev: P) -> ChannelProvider<P>
Creates a new ChannelProvider with the given configuration and previous stage.
Trait Implementations§
Source§impl<P> ChannelReaderProvider for ChannelProvider<P>
impl<P> ChannelReaderProvider for ChannelProvider<P>
Source§fn next_data<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<Option<Bytes>, PipelineErrorKind>> + Send + 'async_trait>>where
'life0: 'async_trait,
ChannelProvider<P>: 'async_trait,
fn next_data<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<Option<Bytes>, PipelineErrorKind>> + Send + 'async_trait>>where
'life0: 'async_trait,
ChannelProvider<P>: 'async_trait,
Pulls the next piece of data from the channel bank. Note that it attempts to pull data out
of the channel bank prior to loading data in (unlike most other stages). This is to
ensure maintain consistency around channel bank pruning which depends upon the order
of operations.
Source§impl<P> Debug for ChannelProvider<P>
impl<P> Debug for ChannelProvider<P>
Source§impl<P> OriginAdvancer for ChannelProvider<P>
impl<P> OriginAdvancer for ChannelProvider<P>
Source§fn advance_origin<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<(), PipelineErrorKind>> + Send + 'async_trait>>where
'life0: 'async_trait,
ChannelProvider<P>: 'async_trait,
fn advance_origin<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<(), PipelineErrorKind>> + Send + 'async_trait>>where
'life0: 'async_trait,
ChannelProvider<P>: 'async_trait,
Advances the internal state of the lowest stage to the next l1 origin.
This method is the equivalent of the reference implementation
advance_l1_block
.Source§impl<P> OriginProvider for ChannelProvider<P>
impl<P> OriginProvider for ChannelProvider<P>
Source§impl<P> SignalReceiver for ChannelProvider<P>
impl<P> SignalReceiver for ChannelProvider<P>
Auto Trait Implementations§
impl<P> Freeze for ChannelProvider<P>where
P: Freeze,
impl<P> RefUnwindSafe for ChannelProvider<P>where
P: RefUnwindSafe,
impl<P> Send for ChannelProvider<P>where
P: Send,
impl<P> Sync for ChannelProvider<P>where
P: Sync,
impl<P> Unpin for ChannelProvider<P>where
P: Unpin,
impl<P> UnwindSafe for ChannelProvider<P>where
P: UnwindSafe,
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 more