Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bytecodealliance/wasmtime-go
Go WebAssembly runtime powered by Wasmtime
https://github.com/bytecodealliance/wasmtime-go
go golang runtime rust wasi wasm wasmtime webassembly
Last synced: 1 day ago
JSON representation
Go WebAssembly runtime powered by Wasmtime
- Host: GitHub
- URL: https://github.com/bytecodealliance/wasmtime-go
- Owner: bytecodealliance
- License: apache-2.0
- Created: 2020-03-27T17:02:00.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-12-20T16:50:14.000Z (about 1 month ago)
- Last Synced: 2025-01-17T12:00:12.193Z (8 days ago)
- Topics: go, golang, runtime, rust, wasi, wasm, wasmtime, webassembly
- Language: Go
- Homepage: https://pkg.go.dev/github.com/bytecodealliance/wasmtime-go
- Size: 2.99 GB
- Stars: 806
- Watchers: 17
- Forks: 80
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - bytecodealliance/wasmtime-go - Go WebAssembly runtime powered by Wasmtime (Go)
README
## Installation
```sh
go get -u github.com/bytecodealliance/wasmtime-go/[email protected]
```Be sure to check out the [API documentation][api]!
This Go library uses CGO to consume the C API of the [Wasmtime
project][wasmtime] which is written in Rust. Precompiled binaries of Wasmtime
are checked into this repository on tagged releases so you won't have to install
Wasmtime locally, but it means that this project only works on Linux x86\_64,
macOS x86\_64 , and Windows x86\_64 currently. Building on other platforms will
need to arrange to build Wasmtime and use `CGO_*` env vars to compile correctly.This project has been tested with Go 1.13 or later.
[api]: https://pkg.go.dev/github.com/bytecodealliance/wasmtime-go/v29
[wasmtime]: https://github.com/bytecodealliance/wasmtimeIf you are a bazel user, add following to your WORKSPACE file:
```
go_repository(
name = "com_github_bytecodealliance_wasmtime_go",
importpath = "github.com/bytecodealliance/wasmtime-go/v29",
version = "v29.0.0",
)
```## Usage
A "Hello, world!" example of using this package looks like:
```go
package mainimport (
"fmt"
"github.com/bytecodealliance/wasmtime-go/v29"
)func main() {
// Almost all operations in wasmtime require a contextual `store`
// argument to share, so create that first
store := wasmtime.NewStore(wasmtime.NewEngine())// Compiling modules requires WebAssembly binary input, but the wasmtime
// package also supports converting the WebAssembly text format to the
// binary format.
wasm, err := wasmtime.Wat2Wasm(`
(module
(import "" "hello" (func $hello))
(func (export "run")
(call $hello))
)
`)
check(err)// Once we have our binary `wasm` we can compile that into a `*Module`
// which represents compiled JIT code.
module, err := wasmtime.NewModule(store.Engine, wasm)
check(err)// Our `hello.wat` file imports one item, so we create that function
// here.
item := wasmtime.WrapFunc(store, func() {
fmt.Println("Hello from Go!")
})// Next up we instantiate a module which is where we link in all our
// imports. We've got one import so we pass that in here.
instance, err := wasmtime.NewInstance(store, module, []wasmtime.AsExtern{item})
check(err)// After we've instantiated we can lookup our `run` function and call
// it.
run := instance.GetFunc(store, "run")
if run == nil {
panic("not a function")
}
_, err = run.Call(store)
check(err)
}func check(e error) {
if e != nil {
panic(e)
}
}
```## Contributing
So far this extension has been written by folks who are primarily Rust
programmers, so it's highly likely that there's some faux pas in terms of Go
idioms. Feel free to send a PR to help make things more idiomatic if you see
something!To work on this extension locally you'll first want to clone the project:
```sh
$ git clone https://github.com/bytecodealliance/wasmtime-go
```Next up you'll want to have a [local Wasmtime build
available](https://bytecodealliance.github.io/wasmtime/contributing-building.html).You'll need to build at least the `wasmtime-c-api` crate, which, at the time of
this writing, would be:```sh
$ cargo build -p wasmtime-c-api
```Once you've got that you can set up the environment of this library with:
```sh
$ ./ci/local.sh /path/to/wasmtime
```This will create a `build` directory which has the compiled libraries and header
files. Next up you can run normal commands such as:```sh
$ go test
```And after that you should be good to go!
### Release Checklist
First run:
```
$ python3 ci/download-wasmtime.py
$ go test
```Make sure everything passes at the current version.
Next run:
```
$ git ls-files | xargs sed -i 's/v16/v17/g'
$ python3 ci/download-wasmtime.py
$ go test
```Fix all errors and such and then commit and make a PR.
Once merged checkout `main` and do:
```
$ rm .gitignore
$ python3 ci/download-wasmtime.py
$ git add .
$ git commit -m 'v29.0.0 release artifacts'
$ git tag v29.0.0
```and push up the tag