pub trait Writable: Readable {
type Mut<R: 'static + ?Sized>: DerefMut<Target = R> + 'static;
// Required methods
fn map_mut<I, U, F>(ref_: Self::Mut<I>, f: F) -> Self::Mut<U>
where F: FnOnce(&mut I) -> &mut U,
I: ?Sized,
U: ?Sized;
fn try_map_mut<I, U, F>(ref_: Self::Mut<I>, f: F) -> Option<Self::Mut<U>>
where F: FnOnce(&mut I) -> Option<&mut U>,
I: ?Sized,
U: ?Sized;
fn try_write(&self) -> Result<Self::Mut<Self::Target>, BorrowMutError>;
// Provided methods
fn write(&mut self) -> Self::Mut<Self::Target> { ... }
fn with_mut<O>(&mut self, f: impl FnOnce(&mut Self::Target) -> O) -> O { ... }
fn set(&mut self, value: Self::Target)
where Self::Target: Sized { ... }
fn toggle(&mut self)
where Self::Target: Not<Output = Self::Target> + Clone { ... }
fn index_mut<I>(
&mut self,
index: I
) -> Self::Mut<<Self::Target as Index<I>>::Output>
where Self::Target: IndexMut<I> { ... }
fn take(&mut self) -> Self::Target
where Self::Target: Default { ... }
fn replace(&mut self, value: Self::Target) -> Self::Target
where Self::Target: Sized { ... }
}
Expand description
A trait for states that can be read from like crate::Signal
, or crate::GlobalSignal
. You may choose to accept this trait as a parameter instead of the concrete type to allow for more flexibility in your API. For example, instead of creating two functions, one that accepts a crate::Signal
and one that accepts a crate::GlobalSignal
, you can create one function that accepts a Writable
type.
Required Associated Types§
Required Methods§
fn try_map_mut<I, U, F>(ref_: Self::Mut<I>, f: F) -> Option<Self::Mut<U>>
fn try_map_mut<I, U, F>(ref_: Self::Mut<I>, f: F) -> Option<Self::Mut<U>>
Try to map the reference to a new type.
Provided Methods§
fn write(&mut self) -> Self::Mut<Self::Target>
fn write(&mut self) -> Self::Mut<Self::Target>
Get a mutable reference to the value. If the value has been dropped, this will panic.
fn with_mut<O>(&mut self, f: impl FnOnce(&mut Self::Target) -> O) -> O
fn with_mut<O>(&mut self, f: impl FnOnce(&mut Self::Target) -> O) -> O
Run a function with a mutable reference to the value. If the value has been dropped, this will panic.
fn set(&mut self, value: Self::Target)
fn set(&mut self, value: Self::Target)
Set the value of the signal. This will trigger an update on all subscribers.
fn toggle(&mut self)
fn toggle(&mut self)
Invert the boolean value of the signal. This will trigger an update on all subscribers.
fn index_mut<I>(
&mut self,
index: I
) -> Self::Mut<<Self::Target as Index<I>>::Output>
fn index_mut<I>( &mut self, index: I ) -> Self::Mut<<Self::Target as Index<I>>::Output>
Index into the inner value and return a reference to the result.