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,

pub const fn new(initializer: fn() -> T) -> GlobalSignal<T>

Create a new global signal with the given initializer.

pub fn signal(&self) -> Signal<T>

Get the signal that backs this global.

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

Run a closure with a mutable reference to the signal’s value. If the signal has been dropped, this will panic.

pub fn map<O>( &self, f: impl Fn(&T) -> &O + 'static ) -> MappedSignal<GenerationalRef<Ref<'static, O>>>

Map the signal to a new type.

pub fn id(&self) -> GenerationalBoxId

Get the generational id of the signal.

Trait Implementations§

§

impl<T> Debug for GlobalSignal<T>where T: Debug + 'static,

§

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

Formats the value using the given formatter. Read more
§

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

§

type Target = dyn Fn() -> T

The resulting type after dereferencing.
§

fn deref(&self) -> &<GlobalSignal<T> as Deref>::Target

Dereferences the value.
§

impl<T> Display for GlobalSignal<T>where T: Display + 'static,

§

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

Formats the value using the given formatter. Read more
§

impl<T> IntoAttributeValue for GlobalSignal<T>where T: 'static + Clone + IntoAttributeValue,

§

fn into_value(self) -> AttributeValue

Convert into an attribute value
§

impl<T> PartialEq<T> for GlobalSignal<T>where T: PartialEq + 'static,

§

fn eq(&self, other: &T) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<T> PartialEq for GlobalSignal<T>where T: 'static,

§

fn eq(&self, other: &GlobalSignal<T>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<T> Readable<T> for GlobalSignal<T>where T: 'static,

§

type Ref<R: 'static + ?Sized> = GenerationalRef<Ref<'static, R>>

The type of the reference.
§

fn map_ref<I, U, F>( ref_: <GlobalSignal<T> as Readable<T>>::Ref<I>, f: F ) -> <GlobalSignal<T> as Readable<T>>::Ref<U>where F: FnOnce(&I) -> &U, U: ?Sized,

Map the reference to a new type.
§

fn try_map_ref<I, U, F>( ref_: <GlobalSignal<T> as Readable<T>>::Ref<I>, f: F ) -> Option<<GlobalSignal<T> as Readable<T>>::Ref<U>>where F: FnOnce(&I) -> Option<&U>, U: ?Sized,

Try to map the reference to a new type.
§

fn read(&self) -> <GlobalSignal<T> as Readable<T>>::Ref<T>

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

fn peek(&self) -> <GlobalSignal<T> as Readable<T>>::Ref<T>

Get the current value of the state without subscribing to updates. If the value has been dropped, this will panic.
§

fn with<O>(&self, f: impl FnOnce(&T) -> O) -> O

Run a function with a reference to the value. If the value has been dropped, this will panic.
§

fn with_peek<O>(&self, f: impl FnOnce(&T) -> O) -> O

Run a function with a reference to the value. If the value has been dropped, this will panic.
§

fn index<I>(&self, index: I) -> Self::Ref<<T as Index<I>>::Output>where T: Index<I>,

Index into the inner value and return a reference to the result. If the value has been dropped or the index is invalid, this will panic.
§

impl<T> Writable<T> for GlobalSignal<T>where T: 'static,

§

type Mut<R: 'static + ?Sized> = Write<R>

The type of the reference.
§

fn map_mut<I, U, F>( ref_: <GlobalSignal<T> as Writable<T>>::Mut<I>, f: F ) -> <GlobalSignal<T> as Writable<T>>::Mut<U>where U: 'static + ?Sized, F: FnOnce(&mut I) -> &mut U,

Map the reference to a new type.
§

fn try_map_mut<I, U, F>( ref_: <GlobalSignal<T> as Writable<T>>::Mut<I>, f: F ) -> Option<<GlobalSignal<T> as Writable<T>>::Mut<U>>where I: 'static, U: 'static + ?Sized, F: FnOnce(&mut I) -> Option<&mut U>,

Try to map the reference to a new type.
§

fn try_write( &self ) -> Result<<GlobalSignal<T> as Writable<T>>::Mut<T>, BorrowMutError>

Try to get a mutable reference to the value. If the value has been dropped, this will panic.
§

fn write(&self) -> Self::Mut<T>

Get a mutable reference to the value. If the value has been dropped, this will panic.
§

fn with_mut<O>(&self, f: impl FnOnce(&mut T) -> 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: T)

Set the value of the signal. This will trigger an update on all subscribers.
§

fn index_mut<I>(&self, index: I) -> Self::Mut<<T as Index<I>>::Output>where T: IndexMut<I>,

Index into the inner value and return a reference to the result.
§

fn replace(&self, value: T) -> T

Replace the value in the Signal, returning the old value.

Auto Trait Implementations§

§

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> 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> Instrument for T

§

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

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

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 = _

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, R> ReadableOptionExt<T> for Rwhere T: 'static, R: Readable<Option<T>>,

§

fn unwrap(&self) -> Twhere T: Clone,

Unwraps the inner value and clones it.
§

fn as_ref(&self) -> Option<Self::Ref<T>>

Attempts to read the inner value of the Option.
§

impl<T, R> ReadableVecExt<T> for Rwhere T: 'static, R: Readable<Vec<T>>,

§

fn len(&self) -> usize

Returns the length of the inner vector.
§

fn is_empty(&self) -> bool

Returns true if the inner vector is empty.
§

fn first(&self) -> Option<Self::Ref<T>>

Get the first element of the inner vector.
§

fn last(&self) -> Option<Self::Ref<T>>

Get the last element of the inner vector.
§

fn get(&self, index: usize) -> Option<Self::Ref<T>>

Get the element at the given index of the inner vector.
§

fn iter(&self) -> ReadableValueIterator<'_, T, Self> where Self: Sized,

Get an iterator over the values of the inner vector.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
§

impl<T, O> SuperFrom<T> for Owhere O: From<T>,

§

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>,

§

fn super_into(self) -> O

Convert from a type to another type.
§

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

§

fn to<T>(self) -> Twhere Self: Into<T>,

Converts to T by calling Into<T>::into.
§

fn try_to<T>(self) -> Result<T, Self::Error>where Self: TryInto<T>,

Tries to convert to T by calling TryInto<T>::try_into.
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T, W> WritableOptionExt<T> for Wwhere T: 'static, W: Writable<Option<T>>,

§

fn get_or_insert(&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(&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.
§

fn as_mut(&self) -> Option<Self::Mut<T>>

Attempts to write the inner value of the Option.
§

impl<T, W> WritableVecExt<T> for Wwhere T: 'static, W: Writable<Vec<T>>,

§

fn push(&mut self, value: T)

Pushes a new value to the end of the vector.
§

fn pop(&mut self) -> Option<T>

Pops the last value from the vector.
§

fn insert(&mut self, index: usize, value: T)

Inserts a new value at the given index.
§

fn remove(&mut self, index: usize) -> T

Removes the value at the given index.
§

fn clear(&mut self)

Clears the vector, removing all values.
§

fn extend(&mut self, iter: impl IntoIterator<Item = T>)

Extends the vector with the given iterator.
§

fn truncate(&mut self, len: usize)

Truncates the vector to the given length.
§

fn swap_remove(&mut self, index: usize) -> T

Swaps two values in the vector.
§

fn retain(&mut self, f: impl FnMut(&T) -> bool)

Retains only the values that match the given predicate.
§

fn split_off(&mut self, at: usize) -> Vec<T>

Splits the vector into two at the given index.
§

fn get_mut(&self, index: usize) -> Option<Self::Mut<T>>

Try to mutably get an element from the vector.
§

fn iter_mut(&self) -> WritableValueIterator<T, Self> where Self: Sized + Clone,

Gets an iterator over the values of the vector.