sqlite/ext/wasm
2022-08-16 16:06:12 +00:00
..
api Add worker-style variant of the tests added in [ae24ac0f7dd9], but building this with wasmfs causes them to throw inexplicable exceptions from the Emscripten glue (without wasmfs it builds and runs fine, but storage is not persistent). 2022-08-13 17:13:16 +00:00
common Corrected TextDecoder.decode() usage to run when its input references a SharedArrayBuffer. 2022-08-13 13:42:07 +00:00
fiddle Remove OPFS from the fiddle build for the time being - will re-enable once the breakage is figured out via testing with the core API. 2022-08-13 13:51:56 +00:00
jaccwabyt Corrected TextDecoder.decode() usage to run when its input references a SharedArrayBuffer. 2022-08-13 13:42:07 +00:00
EXPORTED_FUNCTIONS.fiddle Build fiddle with WASMFS OPFS support and attempt to use it if available. It does not work because of an inexplicable exception in Emscripten-generated code and perpetually-locked db, but it's not yet clear why. 2022-08-12 17:57:09 +00:00
EXPORTED_RUNTIME_METHODS.fiddle wasm/fiddle refactoring part 1 of N: move fiddle app from ext/fiddle to ext/wasm/fiddle, which only contains files intended to be pushed to the live site. Disabled build of the non-fiddle wasm parts, pending a later step of the refactoring. 2022-08-10 09:36:10 +00:00
GNUmakefile wasm: disable shared cache mode by default. Experimentally move wasm-build generated files up one dir to rule the extra dir out as a problem for Emscripten-related worker-loading failures. 2022-08-16 16:06:12 +00:00
README.md wasm/fiddle refactoring part 1 of N: move fiddle app from ext/fiddle to ext/wasm/fiddle, which only contains files intended to be pushed to the live site. Disabled build of the non-fiddle wasm parts, pending a later step of the refactoring. 2022-08-10 09:36:10 +00:00
scratchpad-opfs-main.html Add scratchpad/test app for WASMFS/OPFS running in the main window thread. Enable WASMFS by default in the library build. 2022-08-13 16:11:38 +00:00
scratchpad-opfs-main.js wasmfs: use unix-none VFS by default to avoid locking errors in non-OPFS mode. 2022-08-13 16:36:06 +00:00
scratchpad-opfs-worker.html Add worker-style variant of the tests added in [ae24ac0f7dd9], but building this with wasmfs causes them to throw inexplicable exceptions from the Emscripten glue (without wasmfs it builds and runs fine, but storage is not persistent). 2022-08-13 17:13:16 +00:00
scratchpad-opfs-worker.js Add worker-style variant of the tests added in [ae24ac0f7dd9], but building this with wasmfs causes them to throw inexplicable exceptions from the Emscripten glue (without wasmfs it builds and runs fine, but storage is not persistent). 2022-08-13 17:13:16 +00:00
testing1.html wasm refactoring part 2 of (apparently) 2: moved ext/fiddle/... into ext/wasm and restructured the core API-related parts of the JS/WASM considerably. 2022-08-10 11:26:08 +00:00
testing1.js Cleanups in the wasmfs/opfs integration but disable it in order to get the build into a known-working state before continuing with experimentation. 2022-08-13 13:56:00 +00:00
testing2.html wasm refactoring part 2 of (apparently) 2: moved ext/fiddle/... into ext/wasm and restructured the core API-related parts of the JS/WASM considerably. 2022-08-10 11:26:08 +00:00
testing2.js Cleanups in the wasmfs/opfs integration but disable it in order to get the build into a known-working state before continuing with experimentation. 2022-08-13 13:56:00 +00:00

This directory houses the Web Assembly (WASM) parts of the sqlite3 build.

It requires emscripten and that the build environment be set up for emscripten. A mini-HOWTO for setting that up follows...

First, install the Emscripten SDK, as documented here and summarized below for Linux environments:

# Clone the emscripten repository:
$ git clone https://github.com/emscripten-core/emsdk.git
$ cd emsdk

# Download and install the latest SDK tools:
$ ./emsdk install latest

# Make the "latest" SDK "active" for the current user:
$ ./emsdk activate latest

Those parts only need to be run once, but the SDK can be updated using:

$ git pull
$ ./emsdk activate latest

The following needs to be run for each shell instance which needs the emcc compiler:

# Activate PATH and other environment variables in the current terminal:
$ source ./emsdk_env.sh

$ which emcc
/path/to/emsdk/upstream/emscripten/emcc

Optionally, add that to your login shell's resource file (~/.bashrc or equivalent).

That env script needs to be sourced for building this application from the top of the sqlite3 build tree:

$ make fiddle

Or:

$ cd ext/wasm
$ make

That will generate the fiddle application under ext/fiddle, as fiddle.html. That application cannot, due to XMLHttpRequest security limitations, run if the HTML file is opened directly in the browser (i.e. if it is opened using a file:// URL), so it needs to be served via an HTTP server. For example, using althttpd:

$ cd ext/wasm/fiddle
$ althttpd -page fiddle.html

That will open the system's browser and run the fiddle app's page.

Note that when serving this app via althttpd, it must be a version from 2022-05-17 or newer so that it recognizes the .wasm file extension and responds with the mimetype application/wasm, as the WASM loader is pedantic about that detail.

Known Quirks and Limitations

Some "impedence mismatch" between C and WASM/JavaScript is to be expected.

No I/O

sqlite3 shell commands which require file I/O or pipes are disabled in the WASM build.

exit() Triggered from C

When C code calls exit(), as happens (for example) when running an "unsafe" command when safe mode is active, WASM's connection to the sqlite3 shell environment has no sensible choice but to shut down because exit() leaves it in a state we can no longer recover from. The JavaScript-side application attempts to recognize this and warn the user that restarting the application is necessary. Currently the only way to restart it is to reload the page. Restructuring the shell code such that it could be "rebooted" without restarting the JS app would require some invasive changes which are not currently on any TODO list but have not been entirely ruled out long-term.