GraphiteEditor/Graphite

Restructure JS <-> Wasm communication flow and adopt parallelism

Open

#1,113 opened on Apr 11, 2023

View on GitHub
 (3 comments) (0 reactions) (2 assignees)Rust (25,662 stars) (1,176 forks)batch import
Help WantedPerformanceWeb

Description

Right now, JS calls into Wasm, then that calls back into JS again, and that might call back into Wasm, and so on. It does that within the same call stack, so the call stack gets deeper and deeper ping-ponging between the two languages.

We want to flatten this out and build a queue system so either side can queue up tasks. One side processes its queue while building up a queue for the other side, then when done, it switches to the other side and works through its queue on that side, building up tasks for the other side to complete, then it switches again when the queue is done.

We also want to utilize web workers wherever possible to get everything but the DOM manipulations off the main thread, and also benefit where possible from parallelism.

Contributor guide