ComputedImpl<T> class

Implementation of Computed that automatically updates when its dependencies change.

This is the concrete implementation of the Computed interface. Computed values are derived from other reactive values and are recalculated only when their dependencies change. They are cached and only recompute when necessary, making them efficient for expensive calculations.

See Computed for the public interface and usage examples.

Example:

final firstName = Signal('John');
final lastName = Signal('Doe');
final fullName = Computed(() => '${firstName.value} ${lastName.value}');

print(fullName.value); // "John Doe"
firstName.value = 'Jane';
print(fullName.value); // "Jane Doe" - automatically updated
Inheritance
Implemented types
Mixed-in types
Available extensions

Constructors

ComputedImpl(T getter(), {JoltDebugFn? onDebug})
Creates a new computed value with the given getter function.

Properties

deps Link?
First dependency link in the chain.
getter/setter pairinherited
depsTail Link?
Last dependency link in the chain.
getter/setter pairinherited
flags int
Reactive flags for this node.
getter/setter pairinherited
getter → T Function()
finalinherited
hashCode int
The hash code for this object.
no setterinherited
isDisposed bool
Whether this node has been disposed.
no setterinherited
listenable JoltValueListenable<T>

Available on Readonly<T>, provided by the JoltValueListenableExtension extension

Converts this Jolt value to a Flutter ValueListenable.
no setter
notifier JoltValueNotifier<T>

Available on Readonly<T>, provided by the JoltValueNotifierExtension extension

Converts this Jolt value to a Flutter ValueNotifier.
no setter
peek → T
Returns the current computed value without establishing a reactive dependency.
no setteroverride
peekCached → T
Returns the cached computed value without establishing a reactive dependency.
no setteroverride
pendingValue ↔ T?
getter/setter pairinherited
runtimeType Type
A representation of the runtime type of the object.
no setterinherited
stream Stream<T>

Available on ReadonlyNode<T>, provided by the JoltReadonlyExtension extension

Converts this reactive value to a broadcast stream.
no setter
subs Link?
First subscriber link in the chain.
getter/setter pairinherited
subsTail Link?
Last subscriber link in the chain.
getter/setter pairinherited
value → T
Returns the current computed value and establishes a reactive dependency.
no setteroverride

Methods

dispose() → void
Disposes this node and cleans up resources.
inherited
get() → T
Returns the current computed value and establishes a reactive dependency.
override
listen(void onData(T event)?, {Function? onError, void onDone()?, bool? cancelOnError, bool immediately = false}) StreamSubscription<T>

Available on ReadonlyNode<T>, provided by the JoltReadonlyExtension extension

Creates a stream subscription that listens to changes in this reactive value.
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
notify() → void
Manually notifies all subscribers that this computed value has changed.
override
onDispose() → void
Disposes the computed value and cleans up resources.
override
toString() String
A string representation of this object.
inherited
until(bool predicate(T value)) Future<T>

Available on ReadonlyNode<T>, provided by the JoltReadonlyExtension extension

Waits until the reactive value satisfies a predicate condition.

Operators

operator ==(Object other) bool
The equality operator.
inherited