pub struct BlockBuilder<'a, Block: BlockT, A: ProvideRuntimeApi<Block>, B> { /* private fields */ }
Expand description
Utility for building new (valid) blocks from a stream of extrinsics.
Implementations§
source§impl<'a, Block, A, B> BlockBuilder<'a, Block, A, B>where
Block: BlockT,
A: ProvideRuntimeApi<Block> + 'a,
A::Api: BlockBuilderApi<Block> + ApiExt<Block>,
B: Backend<Block>,
impl<'a, Block, A, B> BlockBuilder<'a, Block, A, B>where
Block: BlockT,
A: ProvideRuntimeApi<Block> + 'a,
A::Api: BlockBuilderApi<Block> + ApiExt<Block>,
B: Backend<Block>,
sourcepub fn new(
api: &'a A,
parent_hash: Block::Hash,
parent_number: NumberFor<Block>,
record_proof: RecordProof,
inherent_digests: Digest,
backend: &'a B,
extrinsics: VecDeque<Block::Extrinsic>,
maybe_inherent_data: Option<InherentData>,
) -> Result<Self, Error>
pub fn new( api: &'a A, parent_hash: Block::Hash, parent_number: NumberFor<Block>, record_proof: RecordProof, inherent_digests: Digest, backend: &'a B, extrinsics: VecDeque<Block::Extrinsic>, maybe_inherent_data: Option<InherentData>, ) -> Result<Self, Error>
Create a new instance of builder based on the given parent_hash
and parent_number
.
While proof recording is enabled, all accessed trie nodes are saved. These recorded trie nodes can be used by a third party to prove the output of this block builder without having access to the full storage.
sourcepub fn prepare_storage_changes_before(
&self,
extrinsic_index: usize,
) -> Result<StorageChanges<Block>, Error>
pub fn prepare_storage_changes_before( &self, extrinsic_index: usize, ) -> Result<StorageChanges<Block>, Error>
Returns the state before executing the extrinsic at given extrinsic index.
sourcepub fn prepare_storage_changes_before_finalize_block(
&self,
) -> Result<StorageChanges<Block>, Error>
pub fn prepare_storage_changes_before_finalize_block( &self, ) -> Result<StorageChanges<Block>, Error>
Returns the state before finalizing the block.
sourcepub fn build(self) -> Result<BuiltBlock<Block>, Error>
pub fn build(self) -> Result<BuiltBlock<Block>, Error>
Consume the builder to build a valid Block
containing all pushed extrinsics.
Returns the build Block
, the changes to the storage and an optional StorageProof
supplied by self.api
, combined as BuiltBlock
.
The storage proof will be Some(_)
when proof recording was enabled.
sourcepub fn create_inherents(
parent_hash: Block::Hash,
api: &ApiRef<'_, A::Api>,
inherent_data: InherentData,
) -> Result<VecDeque<Block::Extrinsic>, Error>
pub fn create_inherents( parent_hash: Block::Hash, api: &ApiRef<'_, A::Api>, inherent_data: InherentData, ) -> Result<VecDeque<Block::Extrinsic>, Error>
Create the inherents for the block.
Returns the inherents created by the runtime or an error if something failed.
sourcepub fn estimate_block_size(&self, include_proof: bool) -> usize
pub fn estimate_block_size(&self, include_proof: bool) -> usize
Estimate the size of the block in the current state.
If include_proof
is true
, the estimated size of the storage proof will be added
to the estimation.
Auto Trait Implementations§
impl<'a, Block, A, B> Freeze for BlockBuilder<'a, Block, A, B>
impl<'a, Block, A, B> RefUnwindSafe for BlockBuilder<'a, Block, A, B>where
<Block as Block>::Hash: RefUnwindSafe,
<A as ProvideRuntimeApi<Block>>::Api: RefUnwindSafe,
B: RefUnwindSafe,
<Block as Block>::Extrinsic: RefUnwindSafe,
impl<'a, Block, A, B> Send for BlockBuilder<'a, Block, A, B>
impl<'a, Block, A, B> Sync for BlockBuilder<'a, Block, A, B>
impl<'a, Block, A, B> Unpin for BlockBuilder<'a, Block, A, B>
impl<'a, Block, A, B> UnwindSafe for BlockBuilder<'a, Block, A, B>where
<Block as Block>::Hash: UnwindSafe,
<A as ProvideRuntimeApi<Block>>::Api: UnwindSafe,
B: RefUnwindSafe,
<Block as Block>::Extrinsic: 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
§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
§fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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>
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>
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§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
T
. Read more§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.