Struct freya::prelude::GlobalSignal
pub struct GlobalSignal<T> { /* private fields */ }
Expand description
A signal that can be accessed from anywhere in the application and created in a static
Implementations§
§impl<T> GlobalSignal<T>where
T: 'static,
impl<T> GlobalSignal<T>where
T: 'static,
pub const fn new(initializer: fn() -> T) -> GlobalSignal<T>
pub const fn new(initializer: fn() -> T) -> GlobalSignal<T>
Create a new global signal with the given initializer.
pub const fn with_key(
initializer: fn() -> T,
key: &'static str
) -> GlobalSignal<T>
pub const fn with_key( initializer: fn() -> T, key: &'static str ) -> GlobalSignal<T>
Create this global signal with a specific key. This is useful for ensuring that the signal is unique across the application and accessible from outside the application too.
pub fn origin_scope(&self) -> ScopeId
pub fn origin_scope(&self) -> ScopeId
Get the scope the signal was created in.
pub fn with_mut<O>(&self, f: impl FnOnce(&mut T) -> O) -> O
pub fn with_mut<O>(&self, f: impl FnOnce(&mut T) -> O) -> O
Run a closure with a mutable reference to the signal’s value. If the signal has been dropped, this will panic.
pub fn id(&self) -> GenerationalBoxId
pub fn id(&self) -> GenerationalBoxId
Get the generational id of the signal.
Trait Implementations§
§impl<T> Debug for GlobalSignal<T>where
T: Debug + 'static,
impl<T> Debug for GlobalSignal<T>where
T: Debug + 'static,
§impl<T> Deref for GlobalSignal<T>where
T: Clone + 'static,
impl<T> Deref for GlobalSignal<T>where
T: Clone + 'static,
Allow calling a signal with signal() syntax
Currently only limited to copy types, though could probably specialize for string/arc/rc
§impl<T> Display for GlobalSignal<T>where
T: Display + 'static,
impl<T> Display for GlobalSignal<T>where
T: Display + 'static,
§impl<T> PartialEq<T> for GlobalSignal<T>where
T: PartialEq + 'static,
impl<T> PartialEq<T> for GlobalSignal<T>where
T: PartialEq + 'static,
§impl<T> Readable for GlobalSignal<T>where
T: 'static,
impl<T> Readable for GlobalSignal<T>where
T: 'static,
§type Storage = UnsyncStorage
type Storage = UnsyncStorage
The type of the storage this readable uses.
§fn try_read_unchecked(
&self
) -> Result<<<GlobalSignal<T> as Readable>::Storage as AnyStorage>::Ref<'static, <GlobalSignal<T> as Readable>::Target>, BorrowError>
fn try_read_unchecked( &self ) -> Result<<<GlobalSignal<T> as Readable>::Storage as AnyStorage>::Ref<'static, <GlobalSignal<T> as Readable>::Target>, BorrowError>
Try to get a reference to the value without checking the lifetime. This will subscribe the current scope to the signal. Read more
§fn try_peek_unchecked(
&self
) -> Result<<<GlobalSignal<T> as Readable>::Storage as AnyStorage>::Ref<'static, <GlobalSignal<T> as Readable>::Target>, BorrowError>
fn try_peek_unchecked( &self ) -> Result<<<GlobalSignal<T> as Readable>::Storage as AnyStorage>::Ref<'static, <GlobalSignal<T> as Readable>::Target>, BorrowError>
Try to peek the current value of the signal without subscribing to updates. If the value has
been dropped, this will return an error. Read more
§fn read(&self) -> <Self::Storage as AnyStorage>::Ref<'_, Self::Target>
fn read(&self) -> <Self::Storage as AnyStorage>::Ref<'_, Self::Target>
Get the current value of the state. If this is a signal, this will subscribe the current scope to the signal.
If the value has been dropped, this will panic. Calling this on a Signal is the same as
using the signal() syntax to read and subscribe to its value
§fn try_read(
&self
) -> Result<<Self::Storage as AnyStorage>::Ref<'_, Self::Target>, BorrowError>
fn try_read( &self ) -> Result<<Self::Storage as AnyStorage>::Ref<'_, Self::Target>, BorrowError>
Try to get the current value of the state. If this is a signal, this will subscribe the current scope to the signal.
§fn read_unchecked(
&self
) -> <Self::Storage as AnyStorage>::Ref<'static, Self::Target>
fn read_unchecked( &self ) -> <Self::Storage as AnyStorage>::Ref<'static, Self::Target>
Get a reference to the value without checking the lifetime. This will subscribe the current scope to the signal. Read more
§fn peek(&self) -> <Self::Storage as AnyStorage>::Ref<'_, Self::Target>
fn peek(&self) -> <Self::Storage as AnyStorage>::Ref<'_, Self::Target>
Get the current value of the state without subscribing to updates. If the value has been dropped, this will panic. Read more
§fn try_peek(
&self
) -> Result<<Self::Storage as AnyStorage>::Ref<'_, Self::Target>, BorrowError>
fn try_peek( &self ) -> Result<<Self::Storage as AnyStorage>::Ref<'_, Self::Target>, BorrowError>
Try to peek the current value of the signal without subscribing to updates. If the value has
been dropped, this will return an error.
§fn peek_unchecked(
&self
) -> <Self::Storage as AnyStorage>::Ref<'static, Self::Target>
fn peek_unchecked( &self ) -> <Self::Storage as AnyStorage>::Ref<'static, Self::Target>
Get the current value of the signal without checking the lifetime. Unlike read, this will not subscribe the current scope to the signal which can cause parts of your UI to not update. Read more
§fn with<O>(&self, f: impl FnOnce(&Self::Target) -> O) -> O
fn with<O>(&self, f: impl FnOnce(&Self::Target) -> O) -> O
Run a function with a reference to the value. If the value has been dropped, this will panic.
§impl<T> Writable for GlobalSignal<T>where
T: 'static,
impl<T> Writable for GlobalSignal<T>where
T: 'static,
§fn map_mut<I, U, F>(
ref_: <GlobalSignal<T> as Writable>::Mut<'_, I>,
f: F
) -> <GlobalSignal<T> as Writable>::Mut<'_, U>
fn map_mut<I, U, F>( ref_: <GlobalSignal<T> as Writable>::Mut<'_, I>, f: F ) -> <GlobalSignal<T> as Writable>::Mut<'_, U>
Map the reference to a new type.
§fn try_map_mut<I, U, F>(
ref_: <GlobalSignal<T> as Writable>::Mut<'_, I>,
f: F
) -> Option<<GlobalSignal<T> as Writable>::Mut<'_, U>>
fn try_map_mut<I, U, F>( ref_: <GlobalSignal<T> as Writable>::Mut<'_, I>, f: F ) -> Option<<GlobalSignal<T> as Writable>::Mut<'_, U>>
Try to map the reference to a new type.
§fn downcast_lifetime_mut<'a, 'b, R>(
mut_: <GlobalSignal<T> as Writable>::Mut<'a, R>
) -> <GlobalSignal<T> as Writable>::Mut<'b, R>where
'a: 'b,
R: 'static + ?Sized,
fn downcast_lifetime_mut<'a, 'b, R>(
mut_: <GlobalSignal<T> as Writable>::Mut<'a, R>
) -> <GlobalSignal<T> as Writable>::Mut<'b, R>where
'a: 'b,
R: 'static + ?Sized,
Downcast a mutable reference in a RefMut to a more specific lifetime Read more
§fn try_write_unchecked(
&self
) -> Result<<GlobalSignal<T> as Writable>::Mut<'static, <GlobalSignal<T> as Readable>::Target>, BorrowMutError>
fn try_write_unchecked( &self ) -> Result<<GlobalSignal<T> as Writable>::Mut<'static, <GlobalSignal<T> as Readable>::Target>, BorrowMutError>
Try to get a mutable reference to the value without checking the lifetime. This will update any subscribers. Read more
§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 try_write(&mut self) -> Result<Self::Mut<'_, Self::Target>, BorrowMutError>
fn try_write(&mut self) -> Result<Self::Mut<'_, Self::Target>, BorrowMutError>
Try to get a mutable reference to the value.
§fn write_unchecked(&self) -> Self::Mut<'static, Self::Target>
fn write_unchecked(&self) -> Self::Mut<'static, Self::Target>
Get a mutable reference to the value without checking the lifetime. This will update any subscribers. Read more
Auto Trait Implementations§
impl<T> Freeze for GlobalSignal<T>
impl<T> RefUnwindSafe for GlobalSignal<T>
impl<T> Send for GlobalSignal<T>
impl<T> Sync for GlobalSignal<T>
impl<T> Unpin for GlobalSignal<T>
impl<T> UnwindSafe for GlobalSignal<T>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
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
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T, R> ReadableOptionExt<T> for R
impl<T, R> ReadableOptionExt<T> for R
§impl<T, E, R> ReadableResultExt<T, E> for R
impl<T, E, R> ReadableResultExt<T, E> for R
§impl<T, R> ReadableVecExt<T> for R
impl<T, R> ReadableVecExt<T> for R
§fn first(&self) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
fn first(&self) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
Get the first element of the inner vector.
§fn last(&self) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
fn last(&self) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
Get the last element of the inner vector.
§fn get(&self, index: usize) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
fn get(&self, index: usize) -> Option<<Self::Storage as AnyStorage>::Ref<'_, T>>
Get the element at the given index of the inner vector.
§fn iter(&self) -> ReadableValueIterator<'_, Self> ⓘwhere
Self: Sized,
fn iter(&self) -> ReadableValueIterator<'_, Self> ⓘwhere
Self: Sized,
Get an iterator over the values of the inner vector.
§impl<T, O> SuperFrom<T> for Owhere
O: From<T>,
impl<T, O> SuperFrom<T> for Owhere
O: From<T>,
§fn super_from(input: T) -> O
fn super_from(input: T) -> O
Convert from a type to another type.
§impl<T, O, M> SuperInto<O, M> for Twhere
O: SuperFrom<T, M>,
impl<T, O, M> SuperInto<O, M> for Twhere
O: SuperFrom<T, M>,
§fn super_into(self) -> O
fn super_into(self) -> O
Convert from a type to another type.
§impl<T> ToSmolStr for T
impl<T> ToSmolStr for T
fn to_smolstr(&self) -> SmolStr
§impl<Cfg> TryIntoConfig for Cfg
impl<Cfg> TryIntoConfig for Cfg
fn into_config(self, config: &mut Option<Cfg>)
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
§impl<T, W> WritableOptionExt<T> for W
impl<T, W> WritableOptionExt<T> for W
§fn get_or_insert(&mut self, default: T) -> Self::Mut<'_, T>
fn get_or_insert(&mut self, default: T) -> Self::Mut<'_, T>
Gets the value out of the Option, or inserts the given value if the Option is empty.
§fn get_or_insert_with(
&mut self,
default: impl FnOnce() -> T
) -> Self::Mut<'_, T>
fn get_or_insert_with( &mut self, default: impl FnOnce() -> T ) -> Self::Mut<'_, T>
Gets the value out of the Option, or inserts the value returned by the given function if the Option is empty.
§impl<T, W> WritableVecExt<T> for W
impl<T, W> WritableVecExt<T> for W
§fn extend(&mut self, iter: impl IntoIterator<Item = T>)
fn extend(&mut self, iter: impl IntoIterator<Item = T>)
Extends the vector with the given iterator.
§fn swap_remove(&mut self, index: usize) -> T
fn swap_remove(&mut self, index: usize) -> T
Swaps two values in the vector.
§fn retain(&mut self, f: impl FnMut(&T) -> bool)
fn retain(&mut self, f: impl FnMut(&T) -> bool)
Retains only the values that match the given predicate.