Struct fuel_vm::storage::PredicateStorage
source · pub struct PredicateStorage;
Expand description
No-op storage used for predicate operations.
The storage implementations are expected to provide KV-like operations for contract operations. However, predicates, as defined in the protocol, cannot execute contract opcodes. This means its storage backend for predicate execution shouldn’t provide any functionality.
Trait Implementations§
source§impl Clone for PredicateStorage
impl Clone for PredicateStorage
source§fn clone(&self) -> PredicateStorage
fn clone(&self) -> PredicateStorage
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for PredicateStorage
impl Debug for PredicateStorage
source§impl Default for PredicateStorage
impl Default for PredicateStorage
source§fn default() -> PredicateStorage
fn default() -> PredicateStorage
Returns the “default value” for a type. Read more
source§impl InterpreterStorage for PredicateStorage
impl InterpreterStorage for PredicateStorage
§type DataError = InterpreterError
type DataError = InterpreterError
Error implementation for reasons unspecified in the protocol.
source§fn block_height(&self) -> Result<u32, InterpreterError>
fn block_height(&self) -> Result<u32, InterpreterError>
Provide the current block height in which the transactions should be
executed.
source§fn timestamp(&self, _height: u32) -> Result<Word, Self::DataError>
fn timestamp(&self, _height: u32) -> Result<Word, Self::DataError>
Return the timestamp of a given block Read more
source§fn block_hash(&self, _block_height: u32) -> Result<Bytes32, InterpreterError>
fn block_hash(&self, _block_height: u32) -> Result<Bytes32, InterpreterError>
Provide the block hash from a given height.
source§fn coinbase(&self) -> Result<Address, InterpreterError>
fn coinbase(&self) -> Result<Address, InterpreterError>
Provide the coinbase address for the VM instructions implementation.
source§fn merkle_contract_state_range(
&self,
_id: &ContractId,
_start_key: &Bytes32,
_range: Word
) -> Result<Vec<Option<Cow<'_, Bytes32>>>, Self::DataError>
fn merkle_contract_state_range( &self, _id: &ContractId, _start_key: &Bytes32, _range: Word ) -> Result<Vec<Option<Cow<'_, Bytes32>>>, Self::DataError>
Fetch a range of values from a key-value mapping in a contract storage.
Returns the full range requested using optional values in case
a requested slot is unset.
source§fn merkle_contract_state_insert_range(
&mut self,
_contract: &ContractId,
_start_key: &Bytes32,
_values: &[Bytes32]
) -> Result<Option<()>, Self::DataError>
fn merkle_contract_state_insert_range( &mut self, _contract: &ContractId, _start_key: &Bytes32, _values: &[Bytes32] ) -> Result<Option<()>, Self::DataError>
Insert a range of key-value mappings into contract storage.
Returns None if any of the keys in the range were previously unset.
source§fn merkle_contract_state_remove_range(
&mut self,
_contract: &ContractId,
_start_key: &Bytes32,
_range: Word
) -> Result<Option<()>, Self::DataError>
fn merkle_contract_state_remove_range( &mut self, _contract: &ContractId, _start_key: &Bytes32, _range: Word ) -> Result<Option<()>, Self::DataError>
Remove a range of key-values from contract storage.
Returns None if any of the keys in the range were already unset.
source§fn deploy_contract(
&mut self,
salt: &Salt,
slots: &[StorageSlot],
contract: &Contract
) -> Result<(), Self::DataError>
fn deploy_contract( &mut self, salt: &Salt, slots: &[StorageSlot], contract: &Contract ) -> Result<(), Self::DataError>
Deploy a contract into the storage
source§fn deploy_contract_with_id(
&mut self,
salt: &Salt,
slots: &[StorageSlot],
contract: &Contract,
root: &Bytes32,
id: &ContractId
) -> Result<(), Self::DataError>
fn deploy_contract_with_id( &mut self, salt: &Salt, slots: &[StorageSlot], contract: &Contract, root: &Bytes32, id: &ContractId ) -> Result<(), Self::DataError>
Deploy a contract into the storage with contract id
source§fn storage_contract(
&self,
id: &ContractId
) -> Result<Option<Cow<'_, Contract>>, Self::DataError>
fn storage_contract( &self, id: &ContractId ) -> Result<Option<Cow<'_, Contract>>, Self::DataError>
Fetch a previously inserted contract code from the chain state for a
given contract.
source§fn storage_contract_insert(
&mut self,
id: &ContractId,
contract: &Contract
) -> Result<Option<Contract>, Self::DataError>
fn storage_contract_insert( &mut self, id: &ContractId, contract: &Contract ) -> Result<Option<Contract>, Self::DataError>
Append a contract to the chain, provided its identifier. Read more
source§fn storage_contract_exists(
&self,
id: &ContractId
) -> Result<bool, Self::DataError>
fn storage_contract_exists( &self, id: &ContractId ) -> Result<bool, Self::DataError>
Check if a provided contract exists in the chain.
source§fn storage_contract_root(
&self,
id: &ContractId
) -> Result<Option<Cow<'_, (Salt, Bytes32)>>, Self::DataError>
fn storage_contract_root( &self, id: &ContractId ) -> Result<Option<Cow<'_, (Salt, Bytes32)>>, Self::DataError>
Fetch a previously inserted salt+root tuple from the chain state for a
given contract.
source§fn storage_contract_root_insert(
&mut self,
id: &ContractId,
salt: &Salt,
root: &Bytes32
) -> Result<Option<(Salt, Bytes32)>, Self::DataError>
fn storage_contract_root_insert( &mut self, id: &ContractId, salt: &Salt, root: &Bytes32 ) -> Result<Option<(Salt, Bytes32)>, Self::DataError>
Append the salt+root of a contract that was appended to the chain.
source§fn merkle_contract_state(
&self,
id: &ContractId,
key: &Bytes32
) -> Result<Option<Cow<'_, Bytes32>>, Self::DataError>
fn merkle_contract_state( &self, id: &ContractId, key: &Bytes32 ) -> Result<Option<Cow<'_, Bytes32>>, Self::DataError>
Fetch the value form a key-value mapping in a contract storage.
source§fn merkle_contract_state_insert(
&mut self,
contract: &ContractId,
key: &Bytes32,
value: &Bytes32
) -> Result<Option<Bytes32>, Self::DataError>
fn merkle_contract_state_insert( &mut self, contract: &ContractId, key: &Bytes32, value: &Bytes32 ) -> Result<Option<Bytes32>, Self::DataError>
Insert a key-value mapping in a contract storage.
source§fn merkle_contract_state_remove(
&mut self,
contract: &ContractId,
key: &Bytes32
) -> Result<Option<Bytes32>, Self::DataError>
fn merkle_contract_state_remove( &mut self, contract: &ContractId, key: &Bytes32 ) -> Result<Option<Bytes32>, Self::DataError>
Remove a key-value mapping from a contract storage.
source§fn merkle_contract_asset_id_balance(
&self,
id: &ContractId,
asset_id: &AssetId
) -> Result<Option<Word>, Self::DataError>
fn merkle_contract_asset_id_balance( &self, id: &ContractId, asset_id: &AssetId ) -> Result<Option<Word>, Self::DataError>
Fetch the balance of an asset ID in a contract storage.
source§fn merkle_contract_asset_id_balance_insert(
&mut self,
contract: &ContractId,
asset_id: &AssetId,
value: Word
) -> Result<Option<Word>, Self::DataError>
fn merkle_contract_asset_id_balance_insert( &mut self, contract: &ContractId, asset_id: &AssetId, value: Word ) -> Result<Option<Word>, Self::DataError>
Update the balance of an asset ID in a contract storage.
source§impl<Key, Type: Mappable> MerkleRootStorage<Key, Type> for PredicateStorage
impl<Key, Type: Mappable> MerkleRootStorage<Key, Type> for PredicateStorage
source§fn root(&self, _parent: &Key) -> Result<MerkleRoot, InterpreterError>
fn root(&self, _parent: &Key) -> Result<MerkleRoot, InterpreterError>
Return the merkle root of the stored
Type
in the storage. Read moresource§impl<Type: Mappable> StorageInspect<Type> for PredicateStorage
impl<Type: Mappable> StorageInspect<Type> for PredicateStorage
type Error = InterpreterError
source§fn get(
&self,
_key: &Type::Key
) -> Result<Option<Cow<'_, Type::OwnedValue>>, InterpreterError>
fn get( &self, _key: &Type::Key ) -> Result<Option<Cow<'_, Type::OwnedValue>>, InterpreterError>
Retrieve
Cow<Value>
such as Key->Value
.source§fn contains_key(&self, _key: &Type::Key) -> Result<bool, InterpreterError>
fn contains_key(&self, _key: &Type::Key) -> Result<bool, InterpreterError>
Return
true
if there is a Key
mapping to a value in the storage.source§impl<Type: Mappable> StorageMutate<Type> for PredicateStorage
impl<Type: Mappable> StorageMutate<Type> for PredicateStorage
source§fn insert(
&mut self,
_key: &Type::Key,
_value: &Type::Value
) -> Result<Option<Type::OwnedValue>, InterpreterError>
fn insert( &mut self, _key: &Type::Key, _value: &Type::Value ) -> Result<Option<Type::OwnedValue>, InterpreterError>
Append
Key->Value
mapping to the storage. Read moresource§fn remove(
&mut self,
_key: &Type::Key
) -> Result<Option<Type::OwnedValue>, InterpreterError>
fn remove( &mut self, _key: &Type::Key ) -> Result<Option<Type::OwnedValue>, InterpreterError>
Remove
Key->Value
mapping from the storage. Read moreimpl Copy for PredicateStorage
Auto Trait Implementations§
impl RefUnwindSafe for PredicateStorage
impl Send for PredicateStorage
impl Sync for PredicateStorage
impl Unpin for PredicateStorage
impl UnwindSafe for PredicateStorage
Blanket Implementations§
source§impl<T> AnyDebug for Twhere
T: Any + Debug,
impl<T> AnyDebug for Twhere T: Any + Debug,
source§fn as_any_ref(&self) -> &(dyn Any + 'static)
fn as_any_ref(&self) -> &(dyn Any + 'static)
Returns a reference to the underlying type as
Any
.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