pub trait Ext {
Show 27 methods
// Required methods
fn initial_storage_at(&self, key: &H256) -> Result<H256, Error>;
fn storage_at(&self, key: &H256) -> Result<H256, Error>;
fn set_storage(&mut self, key: H256, value: H256) -> Result<(), Error>;
fn exists(&self, address: &H160) -> Result<bool, Error>;
fn exists_and_not_null(&self, address: &H160) -> Result<bool, Error>;
fn origin_balance(&self) -> Result<U256, Error>;
fn balance(&self, address: &H160) -> Result<U256, Error>;
fn blockhash(&mut self, number: &U256) -> H256;
fn create(
&mut self,
gas: &U256,
value: &U256,
code: &[u8],
parent_version: &U256,
address: CreateContractAddress,
trap: bool,
) -> Result<ContractCreateResult, TrapKind>;
fn call(
&mut self,
gas: &U256,
sender_address: &H160,
receive_address: &H160,
value: Option<U256>,
data: &[u8],
code_address: &H160,
call_type: ActionType,
trap: bool,
) -> Result<MessageCallResult, TrapKind>;
fn extcode(&self, address: &H160) -> Result<Option<Arc<Vec<u8>>>, Error>;
fn extcodehash(&self, address: &H160) -> Result<Option<H256>, Error>;
fn extcodesize(&self, address: &H160) -> Result<Option<usize>, Error>;
fn log(&mut self, topics: Vec<H256>, data: &[u8]) -> Result<(), Error>;
fn ret(
self,
gas: &U256,
data: &ReturnData,
apply_state: bool,
) -> Result<U256, Error>;
fn suicide(&mut self, refund_address: &H160) -> Result<(), Error>;
fn schedule(&self) -> &Schedule;
fn env_info(&self) -> &EnvInfo;
fn chain_id(&self) -> u64;
fn depth(&self) -> usize;
fn add_sstore_refund(&mut self, value: usize);
fn sub_sstore_refund(&mut self, value: usize);
fn is_static(&self) -> bool;
// Provided methods
fn trace_next_instruction(
&mut self,
_pc: usize,
_instruction: u8,
_current_gas: U256,
) -> bool { ... }
fn trace_prepare_execute(
&mut self,
_pc: usize,
_instruction: u8,
_gas_cost: U256,
_mem_written: Option<(usize, usize)>,
_store_written: Option<(U256, U256)>,
) { ... }
fn trace_failed(&mut self) { ... }
fn trace_executed(
&mut self,
_gas_used: U256,
_stack_push: &[U256],
_mem: &[u8],
) { ... }
}
Expand description
Externalities interface for VVMs
Required Methods§
Sourcefn initial_storage_at(&self, key: &H256) -> Result<H256, Error>
fn initial_storage_at(&self, key: &H256) -> Result<H256, Error>
Returns the storage value for a given key if reversion happens on the current transaction.
Sourcefn set_storage(&mut self, key: H256, value: H256) -> Result<(), Error>
fn set_storage(&mut self, key: H256, value: H256) -> Result<(), Error>
Stores a value for given key.
Sourcefn exists_and_not_null(&self, address: &H160) -> Result<bool, Error>
fn exists_and_not_null(&self, address: &H160) -> Result<bool, Error>
Determine whether an account exists and is not null (zero balance/nonce, no code).
Sourcefn origin_balance(&self) -> Result<U256, Error>
fn origin_balance(&self) -> Result<U256, Error>
Balance of the origin account.
Sourcefn blockhash(&mut self, number: &U256) -> H256
fn blockhash(&mut self, number: &U256) -> H256
Returns the hash of one of the 256 most recent complete blocks.
Sourcefn create(
&mut self,
gas: &U256,
value: &U256,
code: &[u8],
parent_version: &U256,
address: CreateContractAddress,
trap: bool,
) -> Result<ContractCreateResult, TrapKind>
fn create( &mut self, gas: &U256, value: &U256, code: &[u8], parent_version: &U256, address: CreateContractAddress, trap: bool, ) -> Result<ContractCreateResult, TrapKind>
Creates new contract.
Returns gas_left and contract address if contract creation was successful.
Sourcefn call(
&mut self,
gas: &U256,
sender_address: &H160,
receive_address: &H160,
value: Option<U256>,
data: &[u8],
code_address: &H160,
call_type: ActionType,
trap: bool,
) -> Result<MessageCallResult, TrapKind>
fn call( &mut self, gas: &U256, sender_address: &H160, receive_address: &H160, value: Option<U256>, data: &[u8], code_address: &H160, call_type: ActionType, trap: bool, ) -> Result<MessageCallResult, TrapKind>
Message call.
Returns Err, if we run out of gas. Otherwise returns call_result which contains gas left and true if subcall was successfull.
Sourcefn extcode(&self, address: &H160) -> Result<Option<Arc<Vec<u8>>>, Error>
fn extcode(&self, address: &H160) -> Result<Option<Arc<Vec<u8>>>, Error>
Returns code at given address
Sourcefn extcodehash(&self, address: &H160) -> Result<Option<H256>, Error>
fn extcodehash(&self, address: &H160) -> Result<Option<H256>, Error>
Returns code hash at given address
Sourcefn extcodesize(&self, address: &H160) -> Result<Option<usize>, Error>
fn extcodesize(&self, address: &H160) -> Result<Option<usize>, Error>
Returns code size at given address
Sourcefn log(&mut self, topics: Vec<H256>, data: &[u8]) -> Result<(), Error>
fn log(&mut self, topics: Vec<H256>, data: &[u8]) -> Result<(), Error>
Creates log entry with given topics and data
Sourcefn ret(
self,
gas: &U256,
data: &ReturnData,
apply_state: bool,
) -> Result<U256, Error>
fn ret( self, gas: &U256, data: &ReturnData, apply_state: bool, ) -> Result<U256, Error>
Should be called when transaction calls RETURN
opcode.
Returns gas_left if cost of returning the data is not too high.
Sourcefn suicide(&mut self, refund_address: &H160) -> Result<(), Error>
fn suicide(&mut self, refund_address: &H160) -> Result<(), Error>
Should be called when contract commits suicide. Address to which funds should be refunded.
Sourcefn depth(&self) -> usize
fn depth(&self) -> usize
Returns current depth of execution.
If contract A calls contract B, and contract B calls C, then A depth is 0, B is 1, C is 2 and so on.
Sourcefn add_sstore_refund(&mut self, value: usize)
fn add_sstore_refund(&mut self, value: usize)
Increments sstore refunds counter.
Sourcefn sub_sstore_refund(&mut self, value: usize)
fn sub_sstore_refund(&mut self, value: usize)
Decrements sstore refunds counter.
Provided Methods§
Sourcefn trace_next_instruction(
&mut self,
_pc: usize,
_instruction: u8,
_current_gas: U256,
) -> bool
fn trace_next_instruction( &mut self, _pc: usize, _instruction: u8, _current_gas: U256, ) -> bool
Decide if any more operations should be traced. Passthrough for the VM trace.
Sourcefn trace_prepare_execute(
&mut self,
_pc: usize,
_instruction: u8,
_gas_cost: U256,
_mem_written: Option<(usize, usize)>,
_store_written: Option<(U256, U256)>,
)
fn trace_prepare_execute( &mut self, _pc: usize, _instruction: u8, _gas_cost: U256, _mem_written: Option<(usize, usize)>, _store_written: Option<(U256, U256)>, )
Prepare to trace an operation. Passthrough for the VM trace.
For each call of trace_prepare_execute
either trace_failed
or trace_executed
MUST be called.
Sourcefn trace_failed(&mut self)
fn trace_failed(&mut self)
Trace the execution failure of a single instruction.
Sourcefn trace_executed(&mut self, _gas_used: U256, _stack_push: &[U256], _mem: &[u8])
fn trace_executed(&mut self, _gas_used: U256, _stack_push: &[U256], _mem: &[u8])
Trace the finalised execution of a single instruction.