Struct snarkvm_debug::prelude::store::OutputStore
pub struct OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,{ /* private fields */ }Expand description
The transition output store.
Implementations§
§impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
pub fn open(dev: Option<u16>) -> Result<OutputStore<N, O>, Error>
pub fn open(dev: Option<u16>) -> Result<OutputStore<N, O>, Error>
Initializes the transition output store.
pub fn from(storage: O) -> OutputStore<N, O>
pub fn from(storage: O) -> OutputStore<N, O>
Initializes a transition output store from storage.
pub fn insert(
&self,
transition_id: <N as Network>::TransitionID,
outputs: &[Output<N>]
) -> Result<(), Error>
pub fn insert( &self, transition_id: <N as Network>::TransitionID, outputs: &[Output<N>] ) -> Result<(), Error>
Stores the given (transition ID, output) pair into storage.
pub fn remove(
&self,
transition_id: &<N as Network>::TransitionID
) -> Result<(), Error>
pub fn remove( &self, transition_id: &<N as Network>::TransitionID ) -> Result<(), Error>
Removes the output for the given transition ID.
pub fn start_atomic(&self)
pub fn start_atomic(&self)
Starts an atomic batch write operation.
pub fn is_atomic_in_progress(&self) -> bool
pub fn is_atomic_in_progress(&self) -> bool
Checks if an atomic batch is in progress.
pub fn atomic_checkpoint(&self)
pub fn atomic_checkpoint(&self)
Checkpoints the atomic batch.
pub fn clear_latest_checkpoint(&self)
pub fn clear_latest_checkpoint(&self)
Clears the latest atomic batch checkpoint.
pub fn atomic_rewind(&self)
pub fn atomic_rewind(&self)
Rewinds the atomic batch to the previous checkpoint.
pub fn abort_atomic(&self)
pub fn abort_atomic(&self)
Aborts an atomic batch write operation.
pub fn finish_atomic(&self) -> Result<(), Error>
pub fn finish_atomic(&self) -> Result<(), Error>
Finishes an atomic batch write operation.
§impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
pub fn get_output_ids(
&self,
transition_id: &<N as Network>::TransitionID
) -> Result<Vec<Field<N>>, Error>
pub fn get_output_ids( &self, transition_id: &<N as Network>::TransitionID ) -> Result<Vec<Field<N>>, Error>
Returns the output IDs for the given transition ID.
pub fn get_outputs(
&self,
transition_id: &<N as Network>::TransitionID
) -> Result<Vec<Output<N>>, Error>
pub fn get_outputs( &self, transition_id: &<N as Network>::TransitionID ) -> Result<Vec<Output<N>>, Error>
Returns the outputs for the given transition ID.
pub fn get_record(
&self,
commitment: &Field<N>
) -> Result<Option<Record<N, Ciphertext<N>>>, Error>
pub fn get_record( &self, commitment: &Field<N> ) -> Result<Option<Record<N, Ciphertext<N>>>, Error>
Returns the record for the given commitment.
If the record exists, Ok(Some(record)) is returned.
If the record was purged, Ok(None) is returned.
If the record does not exist, Err(error) is returned.
§impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
pub fn find_transition_id(
&self,
output_id: &Field<N>
) -> Result<Option<<N as Network>::TransitionID>, Error>
pub fn find_transition_id( &self, output_id: &Field<N> ) -> Result<Option<<N as Network>::TransitionID>, Error>
Returns the transition ID that contains the given output ID.
§impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
pub fn contains_output_id(&self, output_id: &Field<N>) -> Result<bool, Error>
pub fn contains_output_id(&self, output_id: &Field<N>) -> Result<bool, Error>
Returns true if the given output ID exists.
pub fn contains_commitment(&self, commitment: &Field<N>) -> Result<bool, Error>
pub fn contains_commitment(&self, commitment: &Field<N>) -> Result<bool, Error>
Returns true if the given commitment exists.
pub fn contains_checksum(&self, checksum: &Field<N>) -> bool
pub fn contains_checksum(&self, checksum: &Field<N>) -> bool
Returns true if the given checksum exists.
pub fn contains_nonce(&self, nonce: &Group<N>) -> Result<bool, Error>
pub fn contains_nonce(&self, nonce: &Group<N>) -> Result<bool, Error>
Returns true if the given nonce exists.
§impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
impl<N, O> OutputStore<N, O>where
N: Network,
O: OutputStorage<N>,
pub fn output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the output IDs, for all transition outputs.
pub fn constant_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn constant_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the constant output IDs, for all transition outputs that are constant.
pub fn public_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn public_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the public output IDs, for all transition outputs that are public.
pub fn private_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn private_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the private output IDs, for all transition outputs that are private.
pub fn commitments(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn commitments(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the commitments, for all transition outputs that are records.
pub fn external_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn external_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the external record output IDs, for all transition outputs that are external records.
pub fn future_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn future_output_ids(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the future output IDs, for all transition outputs that are future outputs.
§impl<N, I> OutputStore<N, I>where
N: Network,
I: OutputStorage<N>,
impl<N, I> OutputStore<N, I>where
N: Network,
I: OutputStorage<N>,
pub fn constant_outputs(&self) -> impl Iterator<Item = Cow<'_, Plaintext<N>>>
pub fn constant_outputs(&self) -> impl Iterator<Item = Cow<'_, Plaintext<N>>>
Returns an iterator over the constant outputs, for all transitions.
pub fn public_outputs(&self) -> impl Iterator<Item = Cow<'_, Plaintext<N>>>
pub fn public_outputs(&self) -> impl Iterator<Item = Cow<'_, Plaintext<N>>>
Returns an iterator over the constant outputs, for all transitions.
pub fn private_outputs(&self) -> impl Iterator<Item = Cow<'_, Ciphertext<N>>>
pub fn private_outputs(&self) -> impl Iterator<Item = Cow<'_, Ciphertext<N>>>
Returns an iterator over the private outputs, for all transitions.
pub fn checksums(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
pub fn checksums(&self) -> impl Iterator<Item = Cow<'_, Field<N>>>
Returns an iterator over the checksums, for all transition outputs that are records.
pub fn nonces(&self) -> impl Iterator<Item = Cow<'_, Group<N>>>
pub fn nonces(&self) -> impl Iterator<Item = Cow<'_, Group<N>>>
Returns an iterator over the nonces, for all transition outputs that are records.
pub fn records(
&self
) -> impl Iterator<Item = (Cow<'_, Field<N>>, Cow<'_, Record<N, Ciphertext<N>>>)>
pub fn records( &self ) -> impl Iterator<Item = (Cow<'_, Field<N>>, Cow<'_, Record<N, Ciphertext<N>>>)>
Returns an iterator over the (commitment, record) pairs, for all transition outputs that are records.
pub fn future_outputs(&self) -> impl Iterator<Item = Cow<'_, Future<N>>>
pub fn future_outputs(&self) -> impl Iterator<Item = Cow<'_, Future<N>>>
Returns an iterator over the future outputs, for all transitions.
Trait Implementations§
§impl<N, O> Clone for OutputStore<N, O>where
N: Clone + Network,
O: Clone + OutputStorage<N>,
<O as OutputStorage<N>>::ConstantMap: Clone,
<O as OutputStorage<N>>::PublicMap: Clone,
<O as OutputStorage<N>>::PrivateMap: Clone,
<O as OutputStorage<N>>::RecordMap: Clone,
<O as OutputStorage<N>>::RecordNonceMap: Clone,
<O as OutputStorage<N>>::ExternalRecordMap: Clone,
<O as OutputStorage<N>>::FutureMap: Clone,
impl<N, O> Clone for OutputStore<N, O>where
N: Clone + Network,
O: Clone + OutputStorage<N>,
<O as OutputStorage<N>>::ConstantMap: Clone,
<O as OutputStorage<N>>::PublicMap: Clone,
<O as OutputStorage<N>>::PrivateMap: Clone,
<O as OutputStorage<N>>::RecordMap: Clone,
<O as OutputStorage<N>>::RecordNonceMap: Clone,
<O as OutputStorage<N>>::ExternalRecordMap: Clone,
<O as OutputStorage<N>>::FutureMap: Clone,
§fn clone(&self) -> OutputStore<N, O>
fn clone(&self) -> OutputStore<N, O>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more