[−][src]Struct sp_state_machine::StateMachine
The substrate state machine.
Implementations
impl<'a, B, H, N, Exec> StateMachine<'a, B, H, N, Exec> where
H: Hasher,
H::Out: Ord + 'static + Codec,
Exec: CodeExecutor + Clone + 'static,
B: Backend<H>,
N: BlockNumber,
[src]
H: Hasher,
H::Out: Ord + 'static + Codec,
Exec: CodeExecutor + Clone + 'static,
B: Backend<H>,
N: BlockNumber,
pub fn new(
backend: &'a B,
changes_trie_state: Option<ChangesTrieState<'a, H, N>>,
overlay: &'a mut OverlayedChanges,
offchain_overlay: &'a mut OffchainOverlayedChanges,
exec: &'a Exec,
method: &'a str,
call_data: &'a [u8],
mut extensions: Extensions,
runtime_code: &'a RuntimeCode<'_>,
spawn_handle: impl SpawnNamed + Send + 'static
) -> Self
[src]
backend: &'a B,
changes_trie_state: Option<ChangesTrieState<'a, H, N>>,
overlay: &'a mut OverlayedChanges,
offchain_overlay: &'a mut OffchainOverlayedChanges,
exec: &'a Exec,
method: &'a str,
call_data: &'a [u8],
mut extensions: Extensions,
runtime_code: &'a RuntimeCode<'_>,
spawn_handle: impl SpawnNamed + Send + 'static
) -> Self
Creates new substrate state machine.
pub fn with_storage_transaction_cache(
mut self: Self,
cache: Option<&'a mut StorageTransactionCache<B::Transaction, H, N>>
) -> Self
[src]
mut self: Self,
cache: Option<&'a mut StorageTransactionCache<B::Transaction, H, N>>
) -> Self
Use given cache
as storage transaction cache.
The cache will be used to cache storage transactions that can be build while executing a function in the runtime. For example, when calculating the storage root a transaction is build that will be cached.
pub fn execute(
&mut self,
strategy: ExecutionStrategy
) -> Result<Vec<u8>, Box<dyn Error>>
[src]
&mut self,
strategy: ExecutionStrategy
) -> Result<Vec<u8>, Box<dyn Error>>
Execute a call using the given state backend, overlayed changes, and call executor.
On an error, no prospective changes are written to the overlay.
Note: changes to code will be in place if this call is made again. For running partial blocks (e.g. a transaction at a time), ensure a different method is used.
Returns the SCALE encoded result of the executed function.
pub fn execute_using_consensus_failure_handler<Handler, R, NC>(
&mut self,
manager: ExecutionManager<Handler>,
mut native_call: Option<NC>
) -> Result<NativeOrEncoded<R>, Box<dyn Error>> where
R: Decode + Encode + PartialEq,
NC: FnOnce() -> Result<R, String> + UnwindSafe,
Handler: FnOnce(Result<NativeOrEncoded<R>, Exec::Error>, Result<NativeOrEncoded<R>, Exec::Error>) -> Result<NativeOrEncoded<R>, Exec::Error>,
[src]
&mut self,
manager: ExecutionManager<Handler>,
mut native_call: Option<NC>
) -> Result<NativeOrEncoded<R>, Box<dyn Error>> where
R: Decode + Encode + PartialEq,
NC: FnOnce() -> Result<R, String> + UnwindSafe,
Handler: FnOnce(Result<NativeOrEncoded<R>, Exec::Error>, Result<NativeOrEncoded<R>, Exec::Error>) -> Result<NativeOrEncoded<R>, Exec::Error>,
Execute a call using the given state backend, overlayed changes, and call executor.
On an error, no prospective changes are written to the overlay.
Note: changes to code will be in place if this call is made again. For running partial blocks (e.g. a transaction at a time), ensure a different method is used.
Returns the result of the executed function either in native representation R
or
in SCALE encoded representation.
Trait Implementations
impl<'a, B, H, N, Exec> Drop for StateMachine<'a, B, H, N, Exec> where
H: Hasher,
B: Backend<H>,
N: ChangesTrieBlockNumber,
[src]
H: Hasher,
B: Backend<H>,
N: ChangesTrieBlockNumber,
Auto Trait Implementations
impl<'a, B, H, N, Exec> !RefUnwindSafe for StateMachine<'a, B, H, N, Exec>
[src]
impl<'a, B, H, N, Exec> !Send for StateMachine<'a, B, H, N, Exec>
[src]
impl<'a, B, H, N, Exec> !Sync for StateMachine<'a, B, H, N, Exec>
[src]
impl<'a, B, H, N, Exec> Unpin for StateMachine<'a, B, H, N, Exec> where
N: Unpin,
[src]
N: Unpin,
impl<'a, B, H, N, Exec> !UnwindSafe for StateMachine<'a, B, H, N, Exec>
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
pub fn from_ref(outer: &Outer) -> &T
[src]
Get a reference to the inner from the outer.
pub fn from_mut(outer: &mut Outer) -> &mut T
[src]
Get a mutable reference to the inner from the outer.
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
T: UncheckedFrom<S>,
pub fn unchecked_into(self) -> T
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,