snarkvm_ledger_store

Struct BlockStore

Source
pub struct BlockStore<N: Network, B: BlockStorage<N>> { /* private fields */ }
Expand description

The block store.

Implementations§

Source§

impl<N: Network, B: BlockStorage<N>> BlockStore<N, B>

Source

pub fn open<S: Clone + Into<StorageMode>>(storage: S) -> Result<Self>

Initializes the block store.

Source

pub fn insert(&self, block: &Block<N>) -> Result<()>

Stores the given block into storage.

Source

pub fn remove_last_n_from_tree_only(&self, n: u32) -> Result<()>

Reverts the Merkle tree to its shape before the insertion of the last ‘n’ blocks.

Source

pub fn remove_last_n(&self, n: u32) -> Result<()>

Removes the last ‘n’ blocks from storage.

Source

pub fn transaction_store(&self) -> &TransactionStore<N, B::TransactionStorage>

Returns the transaction store.

Source

pub fn transition_store(&self) -> &TransitionStore<N, B::TransitionStorage>

Returns the transition store.

Source

pub fn start_atomic(&self)

Starts an atomic batch write operation.

Source

pub fn is_atomic_in_progress(&self) -> bool

Checks if an atomic batch is in progress.

Source

pub fn atomic_checkpoint(&self)

Checkpoints the atomic batch.

Source

pub fn clear_latest_checkpoint(&self)

Clears the latest atomic batch checkpoint.

Source

pub fn atomic_rewind(&self)

Rewinds the atomic batch to the previous checkpoint.

Source

pub fn abort_atomic(&self)

Aborts an atomic batch write operation.

Source

pub fn finish_atomic(&self) -> Result<()>

Finishes an atomic batch write operation.

Source

pub fn storage_mode(&self) -> &StorageMode

Returns the storage mode.

Source

pub fn pause_atomic_writes(&self) -> Result<()>

Pauses atomic writes.

Source

pub fn unpause_atomic_writes<const DISCARD_BATCH: bool>(&self) -> Result<()>

Unpauses atomic writes.

Source§

impl<N: Network, B: BlockStorage<N>> BlockStore<N, B>

Source

pub fn find_block_height_from_state_root( &self, state_root: N::StateRoot, ) -> Result<Option<u32>>

Returns the block height that contains the given state root.

Source

pub fn find_block_hash( &self, transaction_id: &N::TransactionID, ) -> Result<Option<N::BlockHash>>

Returns the block hash that contains the given transaction ID.

Source

pub fn find_block_height_from_solution_id( &self, solution_id: &SolutionID<N>, ) -> Result<Option<u32>>

Returns the block height that contains the given solution ID.

Source§

impl<N: Network, B: BlockStorage<N>> BlockStore<N, B>

Source

pub fn current_state_root(&self) -> N::StateRoot

Returns the current state root.

Source

pub fn current_block_height(&self) -> u32

Returns the current block height.

Source

pub fn get_state_root(&self, block_height: u32) -> Result<Option<N::StateRoot>>

Returns the state root that contains the given block height.

Source

pub fn get_state_path_for_commitment( &self, commitment: &Field<N>, ) -> Result<StatePath<N>>

Returns a state path for the given commitment.

Source

pub fn get_previous_block_hash( &self, height: u32, ) -> Result<Option<N::BlockHash>>

Returns the previous block hash of the given block height.

Source

pub fn get_block_hash(&self, height: u32) -> Result<Option<N::BlockHash>>

Returns the block hash for the given block height.

Source

pub fn get_block_height(&self, block_hash: &N::BlockHash) -> Result<Option<u32>>

Returns the block height for the given block hash.

Source

pub fn get_block_header( &self, block_hash: &N::BlockHash, ) -> Result<Option<Header<N>>>

Returns the block header for the given block hash.

Source

pub fn get_block_authority( &self, block_hash: &N::BlockHash, ) -> Result<Option<Authority<N>>>

Returns the block authority for the given block hash.

Source

pub fn get_block_ratifications( &self, block_hash: &N::BlockHash, ) -> Result<Option<Ratifications<N>>>

Returns the block ratifications for the given block hash.

Source

pub fn get_block_solutions( &self, block_hash: &N::BlockHash, ) -> Result<Solutions<N>>

Returns the block solutions for the given block hash.

Source

pub fn get_solution(&self, solution_id: &SolutionID<N>) -> Result<Solution<N>>

Returns the prover solution for the given solution ID.

Source

pub fn get_block_transactions( &self, block_hash: &N::BlockHash, ) -> Result<Option<Transactions<N>>>

Returns the block transactions for the given block hash.

Source

pub fn get_block_aborted_transaction_ids( &self, block_hash: &N::BlockHash, ) -> Result<Option<Vec<N::TransactionID>>>

Returns the block aborted transaction IDs for the given block hash.

Source

pub fn get_transaction( &self, transaction_id: &N::TransactionID, ) -> Result<Option<Transaction<N>>>

Returns the transaction for the given transaction ID.

Source

pub fn get_confirmed_transaction( &self, transaction_id: &N::TransactionID, ) -> Result<Option<ConfirmedTransaction<N>>>

Returns the confirmed transaction for the given transaction ID.

Source

pub fn get_unconfirmed_transaction( &self, transaction_id: &N::TransactionID, ) -> Result<Option<Transaction<N>>>

Returns the unconfirmed transaction for the given transaction ID.

Source

pub fn get_block(&self, block_hash: &N::BlockHash) -> Result<Option<Block<N>>>

Returns the block for the given block hash.

Source

pub fn get_program( &self, program_id: &ProgramID<N>, ) -> Result<Option<Program<N>>>

Returns the program for the given program ID.

Source

pub fn get_batch_certificate( &self, certificate_id: &Field<N>, ) -> Result<Option<BatchCertificate<N>>>

Returns the batch certificate for the given certificate ID.

Source§

impl<N: Network, B: BlockStorage<N>> BlockStore<N, B>

Source

pub fn contains_state_root(&self, state_root: &N::StateRoot) -> Result<bool>

Returns true if the given state root exists.

Source

pub fn contains_block_height(&self, height: u32) -> Result<bool>

Returns true if the given block height exists.

Source

pub fn contains_block_hash(&self, block_hash: &N::BlockHash) -> Result<bool>

Returns true if the given block hash exists.

Source

pub fn contains_transaction_id( &self, transaction_id: &N::TransactionID, ) -> Result<bool>

Returns true if the given transaction ID exists.

Source

pub fn contains_rejected_or_aborted_transaction_id( &self, transaction_id: &N::TransactionID, ) -> Result<bool>

Returns true if the given rejected transaction ID or aborted transaction ID exists.

Source

pub fn contains_rejected_deployment_or_execution_id( &self, rejected_id: &Field<N>, ) -> Result<bool>

Returns true if the given rejected deployment or execution ID.

Source

pub fn contains_certificate(&self, certificate_id: &Field<N>) -> Result<bool>

Returns true if the given certificate ID exists.

Source

pub fn contains_solution_id(&self, solution_id: &SolutionID<N>) -> Result<bool>

Returns true if the given solution ID exists.

Source§

impl<N: Network, B: BlockStorage<N>> BlockStore<N, B>

Source

pub fn state_roots(&self) -> impl '_ + Iterator<Item = Cow<'_, N::StateRoot>>

Returns an iterator over the state roots, for all blocks in self.

Source

pub fn heights(&self) -> impl '_ + Iterator<Item = Cow<'_, u32>>

Returns an iterator over the block heights, for all blocks in self.

Source

pub fn max_height(&self) -> Option<u32>

Returns the height of the latest block in the storage.

Source

pub fn hashes(&self) -> impl '_ + Iterator<Item = Cow<'_, N::BlockHash>>

Returns an iterator over the block hashes, for all blocks in self.

Source

pub fn solution_ids(&self) -> impl '_ + Iterator<Item = Cow<'_, SolutionID<N>>>

Returns an iterator over the solution IDs, for all blocks in self.

Trait Implementations§

Source§

impl<N: Clone + Network, B: Clone + BlockStorage<N>> Clone for BlockStore<N, B>

Source§

fn clone(&self) -> BlockStore<N, B>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

§

impl<N, B> Freeze for BlockStore<N, B>
where B: Freeze,

§

impl<N, B> !RefUnwindSafe for BlockStore<N, B>

§

impl<N, B> Send for BlockStore<N, B>

§

impl<N, B> Sync for BlockStore<N, B>

§

impl<N, B> Unpin for BlockStore<N, B>
where B: Unpin,

§

impl<N, B> !UnwindSafe for BlockStore<N, B>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

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

Source§

fn vzip(self) -> V