You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Currently, in order to deal with events without losing them, while still being able to subscribe to events as they come, you need to do something like this:
// Extends `Signal.Computed` so you can watch it.classBufferSignalextendsSignal.Computed{constructor(opts){super(()=>{this.#state.get()constbuf=this.#buffer
this.#buffer =[]returnbuf},{
....opts,equals: ()=>false,})}
#buffer =[]
#state =newSignal.State()push(...values){this.#buffer.push(...values)this.#state.set(undefined)}}
This kind of notification followed by pulling is a very common pattern. To name some Web APIs that are essentially exposing this very model, but using events instead of watchers:
The push notification -> poll for changes mechanism often used to keep apps up to date (like in Matrix) is little more than a highly async version of this.
As you might imagine from the initial code snippet, there's room for optimization that implementors are uniquely positioned to perform.
The inner computed and state can be fully elided. Instead, the array can be pushed to and returned directly.
No need to compute the equals: () => false, making pushes almost instant.
Userland can implement these as well, but at a cost: you can no longer .watch the signal directly. So the only way to both make it fast and make it compatible with watchers is to make it a built-in.
(Also, it'd be a lot easier for HTML to use it if it's built-in.)
Note: while I mentioned a type of stream as an example of this idiom, I am not proposing any sort of stream be designed in terms of signals. That is out of scope, and I'm skeptical it's even a good idea.
The text was updated successfully, but these errors were encountered:
Currently, in order to deal with events without losing them, while still being able to subscribe to events as they come, you need to do something like this:
This kind of notification followed by pulling is a very common pattern. To name some Web APIs that are essentially exposing this very model, but using events instead of watchers:
MutationObserver
IntersectionObserver
PerformanceObserver
ResizeObserver
PressureObserver
ReportingObserver
event.getCoalescedEvents()
event.getPredictedEvents()
GPUQueue
, indirectly (though it comes with perf risks)Here's a couple other similar patterns I've seen elsewhere:
"readable"
event +stream.read()
idiomAs you might imagine from the initial code snippet, there's room for optimization that implementors are uniquely positioned to perform.
equals: () => false
, making pushes almost instant.Userland can implement these as well, but at a cost: you can no longer
.watch
the signal directly. So the only way to both make it fast and make it compatible with watchers is to make it a built-in.(Also, it'd be a lot easier for HTML to use it if it's built-in.)
Note: while I mentioned a type of stream as an example of this idiom, I am not proposing any sort of stream be designed in terms of signals. That is out of scope, and I'm skeptical it's even a good idea.
The text was updated successfully, but these errors were encountered: