Struct reactive_graph::computed::AsyncDerived

source ·
pub struct AsyncDerived<T, S = SyncStorage> { /* private fields */ }
Expand description

A reactive value that is derived by running an asynchronous computation in response to changes in its sources.

When one of its dependencies changes, this will re-run its async computation, then notify other values that depend on it that it has changed.

This is an arena-allocated type, which is Copy and is disposed when its reactive Owner cleans up. For a reference-counted signal that livesas as long as a reference to it is alive, see ArcAsyncDerived.

§Examples


let signal1 = RwSignal::new(0);
let signal2 = RwSignal::new(0);
let derived = AsyncDerived::new(move || async move {
  // reactive values can be tracked anywhere in the `async` block
  let value1 = signal1.get();
  tokio::time::sleep(std::time::Duration::from_millis(25)).await;
  let value2 = signal2.get();

  value1 + value2
});

// the value can be accessed synchronously as `Option<T>`
assert_eq!(derived.get(), None);
// we can also .await the value, i.e., convert it into a Future
assert_eq!(derived.await, 0);
assert_eq!(derived.get(), Some(0));

signal1.set(1);
// while the new value is still pending, the signal holds the old value
tokio::time::sleep(std::time::Duration::from_millis(5)).await;
assert_eq!(derived.get(), Some(0));

// setting multiple dependencies will hold until the latest change is ready
signal2.set(1);
assert_eq!(derived.await, 2);

§Core Trait Implementations

  • .get() clones the current value as an Option<T>. If you call it within an effect, it will cause that effect to subscribe to the memo, and to re-run whenever the value of the memo changes.
  • .read() returns a guard that allows accessing the value by reference. If you call it within an effect, it will cause that effect to subscribe to the memo, and to re-run whenever the value changes.
    • .read_untracked() gives access to the current value without reactively tracking it.
  • .with() allows you to reactively access the value without cloning by applying a callback function.
    • .with_untracked() allows you to access the value by applying a callback function without reactively tracking it.
  • IntoFuture allows you to create a Future that resolves when this resource is done loading.

Implementations§

source§

impl<T> AsyncDerived<T>
where T: 'static,

source

pub fn new<Fut>(fun: impl Fn() -> Fut + Send + Sync + 'static) -> Self
where T: Send + Sync + 'static, Fut: Future<Output = T> + Send + 'static,

Creates a new async derived computation.

This runs eagerly: i.e., calls fun once when created and immediately spawns the Future as a new task.

source

pub fn new_with_initial<Fut>( initial_value: Option<T>, fun: impl Fn() -> Fut + Send + Sync + 'static, ) -> Self
where T: Send + Sync + 'static, Fut: Future<Output = T> + Send + 'static,

Creates a new async derived computation with an initial value.

If the initial value is Some(_), the task will not be run initially.

source§

impl<T> AsyncDerived<T, LocalStorage>
where T: 'static,

source

pub fn new_unsync<Fut>(fun: impl Fn() -> Fut + 'static) -> Self
where T: 'static, Fut: Future<Output = T> + 'static,

Creates a new async derived computation that will be guaranteed to run on the current thread.

This runs eagerly: i.e., calls fun once when created and immediately spawns the Future as a new task.

source

pub fn new_unsync_with_initial<Fut>( initial_value: Option<T>, fun: impl Fn() -> Fut + 'static, ) -> Self
where T: 'static, Fut: Future<Output = T> + 'static,

Creates a new async derived computation with an initial value. Async work will be guaranteed to run only on the current thread.

If the initial value is Some(_), the task will not be run initially.

source§

impl<T, S> AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source

pub fn ready(&self) -> AsyncDerivedReadyFuture

Returns a Future that is ready when this resource has next finished loading.

source§

impl<T, S> AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source

pub fn by_ref(&self) -> AsyncDerivedRefFuture<T>

Returns a Future that resolves when the computation is finished, and accesses the inner value by reference rather than by cloning it.

Trait Implementations§

source§

impl<T, S> Clone for AsyncDerived<T, S>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T, S> Debug for AsyncDerived<T, S>
where S: Debug,

source§

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

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

impl<T, S> DefinedAt for AsyncDerived<T, S>

source§

fn defined_at(&self) -> Option<&'static Location<'static>>

Returns the location at which the signal was defined. This is usually simply None in release mode.
source§

impl<T, S> Dispose for AsyncDerived<T, S>

source§

fn dispose(self)

Disposes of the signal. This: Read more
source§

impl<T> From<ArcAsyncDerived<T>> for AsyncDerived<T>
where T: Send + Sync + 'static,

source§

fn from(value: ArcAsyncDerived<T>) -> Self

Converts to this type from the input type.
source§

impl<T> FromLocal<ArcAsyncDerived<T>> for AsyncDerived<T, LocalStorage>
where T: 'static,

source§

fn from_local(value: ArcAsyncDerived<T>) -> Self

Converts between the types.
source§

impl<T, S> IntoFuture for AsyncDerived<T, S>
where T: Clone + 'static, S: Storage<ArcAsyncDerived<T>>,

§

type Output = T

The output that the future will produce on completion.
§

type IntoFuture = AsyncDerivedFuture<T>

Which kind of future are we turning this into?
source§

fn into_future(self) -> Self::IntoFuture

Creates a future from a value. Read more
source§

impl<T, S> ReactiveNode for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source§

fn mark_dirty(&self)

Notifies the source’s dependencies that it has changed.
source§

fn mark_check(&self)

Notifies the source’s dependencies that it may have changed.
source§

fn mark_subscribers_check(&self)

Marks that all subscribers need to be checked.
source§

fn update_if_necessary(&self) -> bool

Regenerates the value for this node, if needed, and returns whether it has actually changed or not.
source§

impl<T, S> ReadUntracked for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

§

type Value = ReadGuard<Option<T>, AsyncPlain<Option<T>>>

The guard type that will be returned, which can be dereferenced to the value.
source§

fn try_read_untracked(&self) -> Option<Self::Value>

Returns the guard, or None if the signal has already been disposed.
source§

fn read_untracked(&self) -> Self::Value

Returns the guard. Read more
source§

impl<T, S> Source for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source§

fn add_subscriber(&self, subscriber: AnySubscriber)

Adds a subscriber to this source’s list of dependencies.
source§

fn remove_subscriber(&self, subscriber: &AnySubscriber)

Removes a subscriber from this source’s list of dependencies.
source§

fn clear_subscribers(&self)

Remove all subscribers from this source’s list of dependencies.
source§

impl<T, S> Subscriber for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source§

fn add_source(&self, source: AnySource)

Adds a subscriber to this subscriber’s list of dependencies.
source§

fn clear_sources(&self, subscriber: &AnySubscriber)

Clears the set of sources for this subscriber.
source§

impl<T, S> ToAnySource for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source§

fn to_any_source(&self) -> AnySource

Converts this type to its type-erased equivalent.
source§

impl<T, S> ToAnySubscriber for AsyncDerived<T, S>
where T: 'static, S: Storage<ArcAsyncDerived<T>>,

source§

fn to_any_subscriber(&self) -> AnySubscriber

Converts this type to its type-erased equivalent.
source§

impl<T, S> Copy for AsyncDerived<T, S>

Auto Trait Implementations§

§

impl<T, S> Freeze for AsyncDerived<T, S>

§

impl<T, S = SyncStorage> !RefUnwindSafe for AsyncDerived<T, S>

§

impl<T, S> Send for AsyncDerived<T, S>
where S: Send,

§

impl<T, S> Sync for AsyncDerived<T, S>
where S: Sync,

§

impl<T, S> Unpin for AsyncDerived<T, S>
where S: Unpin,

§

impl<T, S = SyncStorage> !UnwindSafe for AsyncDerived<T, S>

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> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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<T> Read for T
where T: Track + ReadUntracked,

§

type Value = <T as ReadUntracked>::Value

The guard type that will be returned, which can be dereferenced to the value.
source§

fn try_read(&self) -> Option<<T as Read>::Value>

Subscribes to the signal, and returns the guard, or None if the signal has already been disposed.
source§

fn read(&self) -> <T as Read>::Value

Subscribes to the signal, and returns the guard. Read more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> Track for T

source§

fn track(&self)

Subscribes to this signal in the current reactive scope without doing anything with its value.
source§

impl<T, U> TryFrom<U> for T
where 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 T
where 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.
source§

impl<T> With for T
where T: WithUntracked + Track,

§

type Value = <T as WithUntracked>::Value

The type of the value contained in the signal.
source§

fn try_with<U>(&self, fun: impl FnOnce(&<T as With>::Value) -> U) -> Option<U>

Subscribes to the signal, applies the closure to the value, and returns the result, or None if the signal has already been disposed.
source§

fn with<U>(&self, fun: impl FnOnce(&Self::Value) -> U) -> U

Subscribes to the signal, applies the closure to the value, and returns the result. Read more
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
source§

impl<T> WithUntracked for T

§

type Value = <<T as ReadUntracked>::Value as Deref>::Target

The type of the value contained in the signal.
source§

fn try_with_untracked<U>( &self, fun: impl FnOnce(&<T as WithUntracked>::Value) -> U, ) -> Option<U>

Applies the closure to the value, and returns the result, or None if the signal has already been disposed.
source§

fn with_untracked<U>(&self, fun: impl FnOnce(&Self::Value) -> U) -> U

Applies the closure to the value, and returns the result. Read more