Struct Engine

Source
pub struct Engine {
    pub database: Database,
    pub exec_context: ExecContext,
    pub chain_spec: ChainSpec,
    pub chain_extension_handler: ChainExtensionHandler,
    /* private fields */
}
Expand description

The off-chain engine.

Fields§

§database: Database

The environment database.

§exec_context: ExecContext

The current execution context.

§chain_spec: ChainSpec

The chain specification.

§chain_extension_handler: ChainExtensionHandler

Handler for registered chain extensions.

Implementations§

Source§

impl Engine

Source

pub fn new() -> Self

Source§

impl Engine

Source

pub fn transfer(&mut self, dest: H160, value: &[u8]) -> Result<(), Error>

Transfers value from the contract to the destination account.

Source

pub fn deposit_event(&mut self, topics: &[u8], data: &[u8])

Deposits an event identified by the supplied topics and data.

Source

pub fn set_storage(&mut self, key: &[u8], encoded_value: &[u8]) -> Option<u32>

Writes the encoded value into the storage at the given key. Returns the size of the previously stored value at the key if any.

Source

pub fn get_storage(&mut self, key: &[u8]) -> Result<&[u8], Error>

Returns the contract storage bytes at the key if any.

Source

pub fn take_storage(&mut self, key: &[u8]) -> Result<Vec<u8>, Error>

Removes the storage entries at the given key, returning previously stored value at the key if any.

Source

pub fn contains_storage(&mut self, key: &[u8]) -> Option<u32>

Returns the size of the value stored in the contract storage at the key if any.

Source

pub fn clear_storage(&mut self, key: &[u8]) -> Option<u32>

Removes the storage entries at the given key. Returns the size of the previously stored value at the key if any.

Source

pub fn terminate(&mut self, beneficiary: H160) -> !

Remove the calling account and transfer remaining balance.

todo is the following comment still correct? This function never returns. Either the termination was successful and the execution of the destroyed contract is halted. Or it failed during the termination which is considered fatal.

Source

pub fn caller(&self, output: &mut &mut [u8])

Returns the address of the caller.

Source

pub fn balance(&self, output: &mut &mut [u8])

Returns the balance of the executed contract.

Source

pub fn value_transferred(&self, output: &mut &mut [u8])

Returns the transferred value for the called contract.

Source

pub fn address(&self, output: &mut &mut [u8])

Returns the address of the executed contract.

Source

pub fn hash_blake2_256(input: &[u8], output: &mut [u8; 32])

Conduct the BLAKE-2 256-bit hash and place the result into output.

Source

pub fn hash_blake2_128(input: &[u8], output: &mut [u8; 16])

Conduct the BLAKE-2 128-bit hash and place the result into output.

Source

pub fn hash_sha2_256(input: &[u8], output: &mut [u8; 32])

Conduct the SHA-2 256-bit hash and place the result into output.

Source

pub fn hash_keccak_256(input: &[u8], output: &mut [u8; 32])

Conduct the KECCAK 256-bit hash and place the result into output.

Source

pub fn block_number(&self, output: &mut &mut [u8])

Returns the current block number.

Source

pub fn block_timestamp(&self, output: &mut &mut [u8])

Returns the timestamp of the current block.

Source

pub fn minimum_balance(&self, output: &mut &mut [u8])

Returns the minimum balance that is required for creating an account (i.e. the chain’s existential deposit).

Source

pub fn instantiate( &mut self, _code_hash: &[u8], _gas_limit: u64, _endowment: &[u8], _input: &[u8], _out_address: &mut &mut [u8], _out_return_value: &mut &mut [u8], _salt: &[u8], ) -> Result<(), Error>

Source

pub fn call( &mut self, callee: &[u8], _gas_limit: u64, _value: &[u8], input: &[u8], output: &mut &mut [u8], ) -> Result<(), Error>

Source

pub fn weight_to_fee(&self, gas: u64, output: &mut &mut [u8])

Emulates gas price calculation.

Source

pub fn call_chain_extension( &mut self, id: u32, input: &[u8], output: &mut &mut [u8], )

Calls the chain extension method registered at func_id with input.

Source§

impl Engine

Source

pub fn ecdsa_recover( &mut self, signature: &[u8; 65], message_hash: &[u8; 32], output: &mut [u8; 33], ) -> Result<(), Error>

Recovers the compressed ECDSA public key for given signature and message_hash, and stores the result in output.

Source§

impl Engine

Source

pub fn initialize_or_reset(&mut self)

Resets the environment.

Source

pub fn get_contract_storage_rw(&self, addr: H160) -> (usize, usize)

Returns the total number of reads and writes of the contract’s storage.

Source

pub fn count_reads(&self) -> usize

Returns the total number of reads executed.

Source

pub fn count_writes(&self) -> usize

Returns the total number of writes executed.

Source

pub fn set_caller(&mut self, caller: H160)

Sets a caller for the next call.

Source

pub fn set_contract(&mut self, caller: H160)

Sets a known contract by adding it to a vector of known contracts accounts

Source

pub fn set_callee(&mut self, callee: H160)

Sets the callee for the next call.

Source

pub fn count_used_storage_cells(&self, addr: &H160) -> Result<usize, Error>

Returns the amount of storage cells used by the contract addr.

Returns None if the contract addr is non-existent.

Source

pub fn advance_block(&mut self)

Advances the chain by a single block.

Source

pub fn get_callee(&self) -> H160

Returns the callee, i.e. the currently executing contract.

Source

pub fn is_contract(&self, addr: &H160) -> bool

Returns boolean value indicating whether the account is a contract

Source

pub fn get_emitted_events(&self) -> impl Iterator<Item = EmittedEvent>

Returns the recorded emitted events in order.

Source

pub fn get_acc_balance(&self, addr: AccountId) -> Result<u128, Error>

Returns the current balance of addr.

Source

pub fn set_acc_balance(&mut self, addr: AccountId, new_balance: u128)

Sets the balance of addr to new_balance.

Source

pub fn get_balance(&self, addr: H160) -> Result<U256, Error>

Returns the current balance of addr.

Source

pub fn set_balance(&mut self, addr: H160, new_balance: U256)

Sets the balance of addr to new_balance.

Source

pub fn set_value_transferred(&mut self, value: U256)

Sets the value transferred from the caller to the callee as part of the call.

Source

pub fn set_block_timestamp(&mut self, new_block_timestamp: u64)

Set the block timestamp for the execution context.

Source

pub fn set_block_number(&mut self, new_block_number: u32)

Set the block number for the execution context.

Trait Implementations§

Source§

impl Default for Engine

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Engine

§

impl !RefUnwindSafe for Engine

§

impl !Send for Engine

§

impl !Sync for Engine

§

impl Unpin for Engine

§

impl !UnwindSafe for Engine

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
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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
§

impl<T, Outer> IsWrappedBy<Outer> for T
where Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

§

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

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.
§

impl<S, T> UncheckedInto<T> for S
where T: UncheckedFrom<S>,

§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> JsonSchemaMaybe for T