Skip to main content

WebAssembly in Python.

Project description

AppVeyor Build status

wasmpy

WebAssembly in Python.

Wasmpy is a lightweight layer that sits between Python and WebAssembly. When attempting to import a WebAssembly file, the file is converted into machine code for native speeds.

Installing

python3 -m pip install wasmpy

Usage

To get started, first import the wasmpy module to register the WebAssembly import hooks.

Then you can just import wasm_or_wat_file to load a WebAssembly module.

Usage with Python modules

|-  my_module
    |-  __init__.py
    |-  wasm_math.wat
# __init__.py

import wasmpy
from .wasm_math import add
;; wasm_math.wat

(module
    (func (export "add") (param i32 i32) (result i32)
        (i32.add (local.get 0) (local.get 1))
    )
)
>>> import my_module
>>> my_module.add(45, 960)
1005
>>>

Invalid function names

Functions exported from WebAssembly can also be accessed from the module by using their name as a key.

For exported names that aren't valid Python identifiers or which start with a _, this is the only valid way of accessing these functions.

;; wasm_math.wat

(module
    (func (export "add one") (param i32) (result i32)
        (i32.add (local.get 0) (i32.const 1))
    )
)
>>> import wasmpy
>>> import wasm_math
>>> wasm_math["add one"](11)
12
>>>

Building From Source

On Windows this requires the mingw-w64 as tool to be on PATH.

git clone https://github.com/olivi-r/wasmpy.git
cd wasmpy
python3 setup.py assemble
python3 -m pip install .

Limitations

Wasmpy is still in active development, and only supports x86/x86-64 Windows and Linux machines and lacks some key features:

  • most memory instructions
  • most control instructions
  • imports
  • tables

Goals

  • Current target:

    • Reach compatability with the MVP
  • Future Goals

    • Native support for more architectures, particularly those supported by manylinux
    • Interfacing with the Python C API from WebAssembly (in conjunction with the Wasmpy sister project wasmpy-build) to allow compiled extension modules that are platform independent
    • Compatibility with Pyodide
    • Python implementation support for Jython, PyPy etc.
    • Support for WebAssembly proposals
    • Support for WASI snapshots, as well as support for supersets such as WASIX

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wasmpy-0.2.3.tar.gz (52.2 kB view hashes)

Uploaded Source

Built Distributions

wasmpy-0.2.3-cp36-abi3-win_amd64.whl (55.4 kB view hashes)

Uploaded CPython 3.6+ Windows x86-64

wasmpy-0.2.3-cp36-abi3-win32.whl (50.0 kB view hashes)

Uploaded CPython 3.6+ Windows x86

wasmpy-0.2.3-cp36-abi3-musllinux_1_1_x86_64.whl (1.1 MB view hashes)

Uploaded CPython 3.6+ musllinux: musl 1.1+ x86-64

wasmpy-0.2.3-cp36-abi3-musllinux_1_1_i686.whl (1.0 MB view hashes)

Uploaded CPython 3.6+ musllinux: musl 1.1+ i686

wasmpy-0.2.3-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (556.1 kB view hashes)

Uploaded CPython 3.6+ manylinux: glibc 2.17+ x86-64

wasmpy-0.2.3-cp36-abi3-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl (460.4 kB view hashes)

Uploaded CPython 3.6+ manylinux: glibc 2.12+ i686 manylinux: glibc 2.17+ i686

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page