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.6+ on x86_64 Windows, 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:

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

  default export interface {
    run: func()
  }
}

And this demo.py script

from demo import Demo, DemoImports, imports
from wasmtime import Store

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

def main():
    store = Store()
    demo = Demo(store, DemoImports(Host()))
    demo.run(store)

if __name__ == '__main__':
    main()
$ wasm-tools component new demo.wat --wit demo.wit -o demo.wasm
$ python -m wasmtime.bindgen demo.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-6.0.0-py3-none-win_amd64.whl (4.4 MB view details)

Uploaded Python 3Windows x86-64

wasmtime-6.0.0-py3-none-manylinux2014_aarch64.whl (6.4 MB view details)

Uploaded Python 3

wasmtime-6.0.0-py3-none-manylinux1_x86_64.whl (6.5 MB view details)

Uploaded Python 3

wasmtime-6.0.0-py3-none-macosx_11_0_arm64.whl (4.2 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

wasmtime-6.0.0-py3-none-macosx_10_13_x86_64.whl (5.1 MB view details)

Uploaded Python 3macOS 10.13+ x86-64

wasmtime-6.0.0-py3-none-any.whl (4.4 MB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for wasmtime-6.0.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 fe77820fecc6f12da97be35d2a3bf0be8e47904e8b7e75e0e07b156a79eadba0
MD5 64a6ac08b82b0e6ecac571ddce902037
BLAKE2b-256 47696ff7cfd641dff185f84143392e1af984a7253819e43228581cfe918f36df

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for wasmtime-6.0.0-py3-none-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 694420c5049d1bdd767daa7969eb73d1dd70a778f2d831d13c4aa14fe63beeef
MD5 472da56f36fd776fde35d0bec1739037
BLAKE2b-256 2466db21ce091e3e9157263a966137568a12cee27c5abe6bfa830fcacc7d88f2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for wasmtime-6.0.0-py3-none-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 5a457ae39c77521aced2a9d66148a38583965ded101cd97803a2f0aa86139b9e
MD5 c5d62411b6371aca73fa3462e9f04eea
BLAKE2b-256 88be4895f55d5f80b513bfdf2dbff502f428524568bfe0af914f2308eef5a19a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for wasmtime-6.0.0-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 df1e6f735642490de585701c1030dc4e9cc4d853628370183fa3d91e9b5d816c
MD5 40016981e58035342d965168015822ab
BLAKE2b-256 ae2a20a9c3f303fb405c72397bf9cd00a8d465cd53aa5c694972d049a8ced77b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for wasmtime-6.0.0-py3-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 dfb974d82f09f8b9f4993a9c3256c42b40d9f223128f54da7d9a07043645ed35
MD5 5a4f324a57de3b36df85e4290243f6c8
BLAKE2b-256 e7e55b500dbd89f22069d3d664d1bd6e5ca1c6110a27b4a13648e55e80622bcb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: wasmtime-6.0.0-py3-none-any.whl
  • Upload date:
  • Size: 4.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for wasmtime-6.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4b9ccb4c29a6c03729b8eb376de2c7e7e27a92ed5b6f84c2b1a37379eeeeb255
MD5 3125ba3cefd48f600a17b9bdb6244baa
BLAKE2b-256 f6161b1618ab93746ce84a891c27d45179514fada5ba560d8f2c6b84a3fb344e

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