Skip to content

Latest commit

 

History

History
86 lines (54 loc) · 1.65 KB

File metadata and controls

86 lines (54 loc) · 1.65 KB

Use Starlight Enhanced for Starlark in Go to send HTTP(s) requests from inside WASM

Instructions for this devcontainer

Tested with Go 1.22.4, Bun 1.1.12, Deno 1.44.1, 1set/starlight v0.1.1.

Preparation

  1. Open this repo in devcontainer, e.g. using Github Codespaces. Type or copy/paste following commands to devcontainer's terminal.

Building

  1. cd into the folder of this example:
cd browser-and-deno-starlight-enhanced
  1. Install 1set/starlight. This also installs starlark-go as dependency:
go get github.com/1set/starlight
  1. Compile the example:
GOOS=js GOARCH=wasm go build -o main.wasm main.go
  1. Copy the glue JS from Golang distribution to example's folder:
cp "$(go env GOROOT)/misc/wasm/wasm_exec.js" .

Test with browser

  1. Run simple HTTP server to temporarily publish project to Web:
python3 -m http.server

Codespace will show you "Open in Browser" button. Just click that button or obtain web address from "Forwarded Ports" tab.

  1. As index.html and a 12.5M-sized main.wasm are loaded into browser, refer to browser developer console to see the results.

Test with Node.js

Impossible yet due to golang/go#59605.

Test with Bun

  1. Install Bun:
curl -fsSL https://bun.sh/install | bash
  1. Run with Bun:
~/.bun/bin/bun bun.js

Test with Deno

  1. Install Deno:
curl -fsSL https://deno.land/x/install/install.sh | sh
  1. Run with Deno:
~/.deno/bin/deno run --allow-read --allow-net deno.js

Finish

Perform your own experiments if desired.