Struct sp_runtime::offchain::storage_lock::StorageLock
source · [−]pub struct StorageLock<'a, L = Time> { /* private fields */ }
Expand description
Storage based lock.
A lock that is persisted in the DB and provides the ability to guard against
concurrent access in an off-chain worker, with a defined expiry deadline
based on the concrete Lockable
implementation.
Implementations
Create a new storage lock with an explicit instance of a lockable L
.
A single attempt to lock using the storage entry.
Returns a lock guard on success, otherwise an error containing the
<Self::Lockable>::Deadline
in for the currently active lock
by another task Err(<L as Lockable>::Deadline)
.
Repeated lock attempts until the lock is successfully acquired.
If one uses fn forget(..)
, it is highly likely fn try_lock(..)
is the correct API to use instead of fn lock(..)
, since that might
never unlock in the anticipated span i.e. when used with BlockAndTime
during a certain block number span.
Explicitly create a time and block number based storage lock with a non-default expiration duration and block number offset.
Auto Trait Implementations
impl<'a, L> RefUnwindSafe for StorageLock<'a, L> where
L: RefUnwindSafe,
impl<'a, L> Send for StorageLock<'a, L> where
L: Send,
impl<'a, L> Sync for StorageLock<'a, L> where
L: Sync,
impl<'a, L> Unpin for StorageLock<'a, L> where
L: Unpin,
impl<'a, L> UnwindSafe for StorageLock<'a, L> where
L: UnwindSafe,
Blanket Implementations
Mutably borrows from an owned value. Read more
pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘimpl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;
pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘimpl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;
impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;
Convert Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
. Read more
Convert Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read more
Convert &Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s. Read more
Convert &mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s. Read more
The counterpart to unchecked_from
.
Consume self to return an equivalent value of T
.
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more