A Jupyter kernel for the WebAssembly reference interpreter (see webassembly/spec).
You can try this kernel out in an example_notebook.ipynb using Binder:
This kernel requires a Wasm reference interpreter to be available in the environment (e.g. the Wasm interpreter is not distributed with this Python package).
You can clone a WebAssembly spec repo and build the interpreter yourself using the OCaml toolchain.
@awendland provides a pre-compiled variant of the Wasm reference interpreter with language extensions for abstract types at awendland/webassembly-spec-abstypes.
Either:
- Place the interpreter in your
$PATH
with the namewasm
, or - Specify the interpreter's location when installing the kernel with
python -m wasm_spec_kernel.install --interpreter wherever_you_stored_the/interpreter
To install:
pip install wasm_spec_kernel
python -m wasm_spec_kernel.install
To use it, open up a new Jupyter notebook. For example, via:
jupyter notebook
# In the notebook interface, select Wasm from the 'New' menu
jupyter qtconsole --kernel wasm_spec
jupyter console --kernel wasm_spec
This exists because the WebAssembly reference interpreter is written in OCaml and OCaml is difficult to compile to WebAssembly (otherwise the latest reference interpreter could be hosted via v1 WebAssembly already available in evergreen web browsers). A Jupyter kernel should assist with sharing WebAssembly code samples leveraging features from the various forks of the WebAssembly specification.
I created this to share code samples alongside my undergraduate thesis which focuses on using WebAssembly as a Multi-Language Platform.
For details of how this works, see the Jupyter docs on wrapper kernels, and Pexpect's docs on the replwrap module. Note that this kernel reimplements the pexpect.replwrap.REPLWrapper
class so that it works better with the Wasm reference interpreter.
This was based on bash_kernel by Thomas Kluyver. Tests were adapted from jupyter/jupyter_client and ipython/ipykernel.