wasm-persist
v0.0.4
Published
a JS module for creating orthogonal persistent WebAssembly instances
Downloads
8
Readme
SYNOPSIS
This allows you to hibernate a WebAssembly instance and later start it up again at the exact place you left off.
INSTALL
npm install wasm-persist
USAGE
const persist = require('wasm-persist')
...
wasm = persist.prepare(wasm)
const {instance} = await WebAssembly.instantiate(wasm)
// call some exported functions on your instance
// then when you are done
const state = persist.hibernate(instance)
...
// later you can revive the wasm instance
const {instance} = await WebAssembly.instantiate(wasm)
// just call persist.resume with the old state
persist.resume(instance, state)
DESCRIPTION
The Idea for wasm-persist came from orthogonal persistence. wasm-persist injects getter and setter function for each global and exports the memory and table if they exist. Hibernate calls the getters and creates an Object that contains the memory (as a typedArray), the globals, and the function table. Resume does the opposite and calls the setters for the globals and updates the memory and the table. Foreign functions on the table are not handled currently.