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. Read more
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. Read more
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. Read more
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. Read more
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. Read more
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. Read more
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(&mut self, _parent: &Key) -> Result<MerkleRoot, InterpreterError>
fn root(&mut 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::GetValue>>, InterpreterError>
fn get(
&self,
_key: &Type::Key
) -> Result<Option<Cow<'_, Type::GetValue>>, 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.