pub struct ForkStorage<S> {
    pub inner: Arc<RwLock<ForkStorageInner<S>>>,
    pub chain_id: L2ChainId,
}
Expand description

In memory storage, that allows ‘forking’ from other network. If forking is enabled, it reads missing data from remote location. S - is a struct that is used for source of the fork.

Fields§

§inner: Arc<RwLock<ForkStorageInner<S>>>§chain_id: L2ChainId

Implementations§

source§

impl<S: ForkSource> ForkStorage<S>

source

pub fn new( fork: Option<ForkDetails<S>>, system_contracts_options: &Options ) -> Self

source

pub fn load_factory_dep_internal(&self, hash: H256) -> Option<Vec<u8>>

source§

impl<S> ForkStorage<S>

source

pub fn set_value(&mut self, key: StorageKey, value: StorageValue)

source

pub fn store_factory_dep(&mut self, hash: H256, bytecode: Vec<u8>)

Trait Implementations§

source§

impl<S: Clone> Clone for ForkStorage<S>

source§

fn clone(&self) -> ForkStorage<S>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<S: Debug> Debug for ForkStorage<S>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<S: Debug + ForkSource> ReadStorage for &ForkStorage<S>

source§

fn read_value(&mut self, key: &StorageKey) -> StorageValue

Read value of the key.
source§

fn is_write_initial(&mut self, key: &StorageKey) -> bool

Checks whether a write to this storage at the specified key would be an initial write. Roughly speaking, this is the case when the storage doesn’t contain key, although in case of mutable storages, the caveats apply (a write to a key that is present in the storage but was not committed is still an initial write).
source§

fn load_factory_dep(&mut self, hash: H256) -> Option<Vec<u8>>

Load the factory dependency code by its hash.
§

fn is_bytecode_known(&mut self, bytecode_hash: &H256) -> bool

Returns whether a bytecode hash is “known” to the system.
source§

impl<S: Debug + ForkSource> ReadStorage for ForkStorage<S>

source§

fn is_write_initial(&mut self, key: &StorageKey) -> bool

Checks whether a write to this storage at the specified key would be an initial write. Roughly speaking, this is the case when the storage doesn’t contain key, although in case of mutable storages, the caveats apply (a write to a key that is present in the storage but was not committed is still an initial write).
source§

fn load_factory_dep(&mut self, hash: H256) -> Option<Vec<u8>>

Load the factory dependency code by its hash.
source§

fn read_value(&mut self, key: &StorageKey) -> StorageValue

Read value of the key.
§

fn is_bytecode_known(&mut self, bytecode_hash: &H256) -> bool

Returns whether a bytecode hash is “known” to the system.

Auto Trait Implementations§

§

impl<S> RefUnwindSafe for ForkStorage<S>

§

impl<S> Send for ForkStorage<S>where S: Send + Sync,

§

impl<S> Sync for ForkStorage<S>where S: Send + Sync,

§

impl<S> Unpin for ForkStorage<S>

§

impl<S> UnwindSafe for ForkStorage<S>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for Twhere T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<T> Instrument for T

source§

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

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

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 Twhere 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for Twhere T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

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
source§

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

§

impl<T> MaybeSend for Twhere T: Send,