Skip to main content

python bindings for the binaryen webassembly library

Project description

Latest Version

Python interface to the Binaryen library

This module provides a Python interface to the binaryen webassembly library.

That library has to be installed separately, make sure it is available on your system as a shared library. You may need to add something to your link library search path to let python pick it up.

Requires Python 3.6 or newer. Also works on pypy3 (because it uses cffi). The minor version number of this library tracks the binaryen release number (such as 112)

Software license: MIT

Installation

This Python package expects binaryen to be installed in /usr/include/ and /usr/lib/. On some Linux distributions community packages are available which install Binaryen in the correct place, have a search first to see if that's available for your distribution.

For distributions that don't have this, you build from source or download a release from https://github.com/WebAssembly/binaryen/releases and install it manually.

Manual Installation

Manual installation can be done by extracting the archive, and copying (or symlinking) the files in it to the appropriate location in /usr/.

As an example here is what this might look like in GitHub Actions CI (for Ubuntu 22.04):

    - name: Install Binaryen
      run: |
        wget https://github.com/WebAssembly/binaryen/releases/download/version_109/binaryen-version_109-x86_64-linux.tar.gz
        tar -xf binaryen-version_109-x86_64-linux.tar.gz
        sudo ln -s $PWD/binaryen-version_109/include/binaryen-c.h /usr/include/binaryen-c.h
        sudo ln -s $PWD/binaryen-version_109/include/wasm-delegations.def /usr/include/wasm-delegations.def
        sudo ln -s $PWD/binaryen-version_109/lib/libbinaryen.a /usr/lib/libbinaryen.a

Example

Running the following code:

import binaryen

module = binaryen.ModuleCreate()
params = binaryen.TypeCreate([binaryen.TypeInt32(), binaryen.TypeInt32()], 2)
results = binaryen.TypeInt32()
x = binaryen.LocalGet(module, 0, binaryen.TypeInt32())
y = binaryen.LocalGet(module, 1, binaryen.TypeInt32())
add = binaryen.Binary(module, binaryen.AddInt32(), x, y)
adder = binaryen.AddFunction(module, b"adder", params, results, binaryen.ffi.NULL, 0, add)
binaryen.ModulePrint(module)
binaryen.ModuleDispose(module)

results in the following Webasm Text output:

(module
 (type $i32_i32_=>_i32 (func (param i32 i32) (result i32)))
 (func $adder (; 0 ;) (param $0 i32) (param $1 i32) (result i32)
  (i32.add
   (local.get $0)
   (local.get $1)
  )
 )
)

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

pybinaryen-1.124.tar.gz (17.4 kB view details)

Uploaded Source

Built Distribution

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

pybinaryen-1.124-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file pybinaryen-1.124.tar.gz.

File metadata

  • Download URL: pybinaryen-1.124.tar.gz
  • Upload date:
  • Size: 17.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pybinaryen-1.124.tar.gz
Algorithm Hash digest
SHA256 1db98a407c489397279f7185998e769341bb0d334a6051f91ffdb950d671cf14
MD5 7ba23cd6eb1562606e87f4fd7475d193
BLAKE2b-256 6bec13aba62ea7ac8bb74c480c0be9e73d44d4109fff5a75679a5c98d752a5cf

See more details on using hashes here.

File details

Details for the file pybinaryen-1.124-py3-none-any.whl.

File metadata

  • Download URL: pybinaryen-1.124-py3-none-any.whl
  • Upload date:
  • Size: 14.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pybinaryen-1.124-py3-none-any.whl
Algorithm Hash digest
SHA256 85ab1ffe0ac866ad3e5808d4f0980f7fc0a7f3da4784b038df5c332328574652
MD5 af35cb6dfdf3913e81e1c44bdf551968
BLAKE2b-256 4fcd755754d69f6141ee96c52843344d0b72fc3c3a7e4c97e00d2c6fc9c52a3f

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