eyeball

Struct ObservableWriteGuard

Source
pub struct ObservableWriteGuard<'a, T: 'a, L: Lock = SyncLock> { /* private fields */ }
Expand description

A write guard for the inner value of an observable.

Note that as long as an ObservableWriteGuard is kept alive, the associated SharedObservable is locked and can not be updated except through that guard.

Implementations§

Source§

impl<'a, T: 'a, L: Lock> ObservableWriteGuard<'a, T, L>

Source

pub fn set(this: &mut Self, value: T) -> T

Set the inner value to the given value, notify subscribers and return the previous value.

Source

pub fn set_if_not_eq(this: &mut Self, value: T) -> Option<T>
where T: PartialEq,

Set the inner value to the given value if it doesn’t compare equal to the existing value.

If the inner value is set, subscribers are notified and Some(previous_value) is returned. Otherwise, None is returned.

Source

pub fn set_if_hash_not_eq(this: &mut Self, value: T) -> Option<T>
where T: Hash,

Set the inner value to the given value if it has a different hash than the existing value.

If the inner value is set, subscribers are notified and Some(previous_value) is returned. Otherwise, None is returned.

Source

pub fn take(this: &mut Self) -> T
where T: Default,

Set the inner value to a Default instance of its type, notify subscribers and return the previous value.

Shorthand for ObservableWriteGuard::set(this, T::default()).

Source

pub fn update(this: &mut Self, f: impl FnOnce(&mut T))

Update the inner value and notify subscribers.

Note that even if the inner value is not actually changed by the closure, subscribers will be notified as if it was. Use update_if if you want to conditionally mutate the inner value.

Source

pub fn update_if(this: &mut Self, f: impl FnOnce(&mut T) -> bool)

Maybe update the inner value and notify subscribers if it changed.

The closure given to this function must return true if subscribers should be notified of a change to the inner value.

Trait Implementations§

Source§

impl<T: Debug> Debug for ObservableWriteGuard<'_, T>

Source§

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

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

impl<T, L: Lock> Deref for ObservableWriteGuard<'_, T, L>

Source§

type Target = T

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.

Auto Trait Implementations§

§

impl<'a, T, L> Freeze for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: Freeze,

§

impl<'a, T, L> RefUnwindSafe for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: RefUnwindSafe,

§

impl<'a, T, L> Send for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: Send,

§

impl<'a, T, L> Sync for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: Sync,

§

impl<'a, T, L> Unpin for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: Unpin,

§

impl<'a, T, L> UnwindSafe for ObservableWriteGuard<'a, T, L>
where <L as Lock>::RwLockWriteGuard<'a, ObservableState<T>>: UnwindSafe,

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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 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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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.
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