Skip to main content

A WebAssembly runtime powered by Wasmtime

Project description

wasmtime-py

Python embedding of Wasmtime

A Bytecode Alliance project

CI status Latest Version Latest Version Documentation Code Coverage

Installation

To install wasmtime-py, run this command in your terminal:

$ pip install wasmtime

The package currently supports 64-bit builds of Python 3.8+ on x86_64 Windows, macOS, and Linux, as well as on arm64 macOS and Linux.

Versioning

wasmtime-py follows the Wasmtime versioning scheme, with a new major version being released every month. As with Wasmtime itself, new major versions of wasmtime-py can contain changes that break code written against the previous major version.

Since every installed Python package needs to agree on a single version of wasmtime-py, to use the upper bound on the major version in the dependency requirement should be bumped reguarly, ideally as soon as a new wasmtime-py version is released. To automate this process it is possible to use the whitequark/track-pypi-dependency-version script. YoWASP/runtime is an example of a project that automatically publishes releases on PyPI once a new version of wasmtime-py is released if it passes the testsuite.

Usage

In this example, we compile and instantiate a WebAssembly module and use it from Python:

from wasmtime import Store, Module, Instance, Func, FuncType

store = Store()
module = Module(store.engine, """
  (module
    (func $hello (import "" "hello"))
    (func (export "run") (call $hello))
  )
""")

def say_hello():
    print("Hello from Python!")
hello = Func(store, FuncType([], []), say_hello)

instance = Instance(store, module, [hello])
run = instance.exports(store)["run"]
run(store)

Be sure to check out the examples directory, which has other usage patterns as well as the full API documentation of the wasmtime-py package.

If your WebAssembly module works this way, then you can also import the WebAssembly module directly into Python without explicitly compiling and instantiating it yourself:

# Import the custom loader for `*.wasm` files
import wasmtime.loader

# Assuming `your_wasm_file.wasm` is in the python load path...
import your_wasm_file

# Now you're compiled and instantiated and ready to go!
print(your_wasm_file.run())

Components

The wasmtime package has initial support for running WebAssembly components in Python with high-level bindings. WebAssembly components are defined by the component model and are a flagship feature under development for Wasmtime and its bindings. Components enable communication between the host and WebAssembly guests with richer types than the numerical primitives supported by core WebAssembly. For example with a component Python can pass a string to wasm and back.

Components are represented as *.wasm binaries in the same manner as core WebAssembly modules. With a component binary you can generate Python bindings with:

$ python -m wasmtime.bindgen the-component.wasm --out-dir the-bindings

An example of using this can be done with the wasm-tools repository. For example with this core wasm module at demo.wat:

(module
  (import "python" "print" (func $print (param i32 i32)))
  (memory (export "memory") 1)

  (func (export "run")
    i32.const 100   ;; base pointer of string
    i32.const 13    ;; length of string
    call $print)

  (data (i32.const 100) "Hello, world!")
)

and with this *.wit interface at demo.wit:

package my:demo

world demo {
  import python: interface {
    print: func(s: string)
  }

  export run: func()
}

And this demo.py script

from demo import Root, RootImports, imports
from wasmtime import Store

class Host(imports.Python):
    def print(self, s: str):
        print(s)

def main():
    store = Store()
    demo = Root(store, RootImports(Host()))
    demo.run(store)

if __name__ == '__main__':
    main()
$ wasm-tools component embed demo.wit demo.wat -o demo.wasm
$ wasm-tools component new demo.wasm -o demo.component.wasm
$ python -m wasmtime.bindgen demo.component.wasm --out-dir demo
$ python demo.py
Hello, world!

The generated package demo has all of the requisite exports/imports into the component bound. The demo package is additionally annotated with types to assist with type-checking and self-documentation as much as possible.

Contributing

See CONTRIBUTING.md.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

wasmtime-19.0.0-py3-none-win_amd64.whl (3.9 MB view details)

Uploaded Python 3Windows x86-64

wasmtime-19.0.0-py3-none-manylinux2014_aarch64.whl (4.8 MB view details)

Uploaded Python 3

wasmtime-19.0.0-py3-none-manylinux1_x86_64.whl (4.9 MB view details)

Uploaded Python 3

wasmtime-19.0.0-py3-none-macosx_11_0_arm64.whl (4.1 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

wasmtime-19.0.0-py3-none-macosx_10_13_x86_64.whl (4.6 MB view details)

Uploaded Python 3macOS 10.13+ x86-64

wasmtime-19.0.0-py3-none-any.whl (3.9 MB view details)

Uploaded Python 3

File details

Details for the file wasmtime-19.0.0-py3-none-win_amd64.whl.

File metadata

  • Download URL: wasmtime-19.0.0-py3-none-win_amd64.whl
  • Upload date:
  • Size: 3.9 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.18

File hashes

Hashes for wasmtime-19.0.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 7b8eb96d270e042442389a3d13c1d51b44c55e5d53c27e33a934d22ef6e2a95f
MD5 3aa0c8607e2090e69861e44e277dd493
BLAKE2b-256 be02226d24ff395d4cc2d67bcfe914d8505a5e5b9487e022ae0965d9464bca8f

See more details on using hashes here.

File details

Details for the file wasmtime-19.0.0-py3-none-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for wasmtime-19.0.0-py3-none-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 85890d926adad42dbfe5a772796f452fc42f87a4fda3b982cea842c52dbf734f
MD5 d55eb75389f6e685c3b158913ea8a0ad
BLAKE2b-256 878751100b982f9b092b7241433ea05940a9c3a62db3514eb3d7dc63bceff895

See more details on using hashes here.

File details

Details for the file wasmtime-19.0.0-py3-none-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for wasmtime-19.0.0-py3-none-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 d844128add3ba40d3a667115812ed8064089a76e775c49dc4d43dcf034c15436
MD5 44655bf0809bf294d3d124df70304b2a
BLAKE2b-256 e4b0f61f073125039190df5a4401f7e9af844839b9a96f202850f97919d083ae

See more details on using hashes here.

File details

Details for the file wasmtime-19.0.0-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for wasmtime-19.0.0-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6e0625e3d9b5fa850f6098fad3d081f496095f4705c76bf88144d3dec20e6557
MD5 99b4b4862966b94daae813a32e25cd0b
BLAKE2b-256 368418ee1eb0def7e7341c90063cef1a01794cc1257c4f7948cf26ef364455e8

See more details on using hashes here.

File details

Details for the file wasmtime-19.0.0-py3-none-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for wasmtime-19.0.0-py3-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 43fb95b952b4387a852834477d8d094f3891cdccd4c0f6c8833cfafb5ec8d35b
MD5 43a7230af05be0b94fc08c9f497fdf6a
BLAKE2b-256 ff43a2db7fcf78c2c1f2928766345a0537f2276544efccd48970d02d20895483

See more details on using hashes here.

File details

Details for the file wasmtime-19.0.0-py3-none-any.whl.

File metadata

  • Download URL: wasmtime-19.0.0-py3-none-any.whl
  • Upload date:
  • Size: 3.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.18

File hashes

Hashes for wasmtime-19.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 229075695c97d3220336ab08a0cf6350c6f29b29663b3530d25a9d8aa59db801
MD5 c6d36490b8b8280f623358f73ce0d66b
BLAKE2b-256 dfd3e23729f9cc6d821d510b77314a2554b878f26a5c10cff4f4fe93b5c38073

See more details on using hashes here.

Supported by

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