This project is part of the @thi.ng/umbrella monorepo.
Delayed & scheduled function execution (via setTimeout() etc.) for hybrid WASM apps. This is a support package for @thi.ng/wasm-api.
The package provides a WASM bridge API and abstraction for scheduling function calls via:
- once:
setTimeout()
/clearTimeout()
- interval:
setInterval()
/clearInterval()
- immediate:
setImmediate()
/clearImmediate()
These different types of delayed execution are unified into the single
schedule()
function and the TimerType
enum. Scheduled callbacks can be
cancelled via cancel()
...
Zig example:
const wasm = @import("wasmapi");
const schedule = @import("schedule");
// ...
// the WASM API modules auto-initialize themselves if the root source
// file exposes a `WASM_ALLOCATOR`, otherwise you'll have to initialize manually:
try schedule.init(customAllocator);
// user callback function
fn exampleCallback(raw: ?*anyopaque) void {
if (wasm.ptrCast(*u32, raw)) |state| {
// do something ...
}
}
// arbitrary user state
var state: u32 = 0xdecafbad;
// schedule a single/one-off callback 500ms in the future
const listenerID = try schedule.schedule(
.once,
&.{ .callback = exampleCallback, .ctx = &state },
500,
);
// ...or maybe cancel it again
schedule.cancel(listenerID);
Also see zig-counter example project for more advanced usage...
ALPHA - bleeding edge / work-in-progress
Search or submit any issues for this package
yarn add @thi.ng/wasm-api-schedule
ES module import:
<script type="module" src="https://cdn.skypack.dev/@thi.ng/wasm-api-schedule"></script>
For Node.js REPL:
# with flag only for < v16
node --experimental-repl-await
> const wasmApiSchedule = await import("@thi.ng/wasm-api-schedule");
Package sizes (gzipped, pre-treeshake): ESM: 437 bytes
Several demos in this repo's /examples directory are using this package.
A selection:
Screenshot | Description | Live demo | Source |
---|---|---|---|
Simple Zig/WASM click counter DOM component | Demo | Source | |
Zig-based To-Do list, DOM creation, local storage task persistence | Demo | Source |
TODO
Karsten Schmidt
If this project contributes to an academic publication, please cite it as:
@misc{thing-wasm-api-schedule,
title = "@thi.ng/wasm-api-schedule",
author = "Karsten Schmidt",
note = "https://thi.ng/wasm-api-schedule",
year = 2022
}
© 2022 Karsten Schmidt // Apache Software License 2.0