Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vicradon/golang-wasm-demo
A demo application for adding numbers using a wasm binary
https://github.com/vicradon/golang-wasm-demo
Last synced: 29 days ago
JSON representation
A demo application for adding numbers using a wasm binary
- Host: GitHub
- URL: https://github.com/vicradon/golang-wasm-demo
- Owner: vicradon
- Created: 2024-09-10T03:15:25.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-09-10T05:05:19.000Z (4 months ago)
- Last Synced: 2024-09-10T07:32:09.703Z (4 months ago)
- Language: JavaScript
- Homepage: https://vicradon.github.io/golang-wasm-demo/
- Size: 1.11 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# WASM:Golang + JS Demo
This is a very simple demo of using Golang to generate WebAssembly and then using it on the browser. The Go code is a simple sum function.
![App Screenshot](./docs/app.png)
## Building the target
You can build the browser and WASI targets by running make. All specifics are in the Makefile. If you don't have make installed, you can use the following commands:
```sh
GOOS=wasip1 GOARCH=wasm go build -o wasi/app.wasm wasi/main.go
GOOS=js GOARCH=wasm go build -o web/browser.wasm main.go
```## Running the wasi target
You can run the wasi target directly on your machine using wasmtime. Install it from the [official website](https://wasmtime.dev/) and then run it like so:
```sh
wasmtime wasi/app.wasm
```Sample output:
```
╰─$ wasmtime wasi/app.wasm
Hello Golang!
Pass two numbers to sum
```## Running the browser target
You can run the browser target by serving the content in the web directory using your favourite static file server. Here's a command that uses Python's http.server:
```sh
python3 -m http.server -d web 4500
```This runs the app on port 4500 on all interfaces.