From a249c2edcb0bad48057ed0daa37cdf3e6ad0550b Mon Sep 17 00:00:00 2001 From: Zxilly <31370133+Zxilly@users.noreply.github.com> Date: Tue, 29 Oct 2024 23:25:54 +0800 Subject: [PATCH] add support for go1.24 (#68) * fix: hack to handle the go toolchain * fix: typo * feat: also find new location for wasm_exec.js * feat: remove fallback * feat: return error to let exit happen elsewhere Co-authored-by: Agniva De Sarker * added import --------- Co-authored-by: Agniva De Sarker --- handler.go | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/handler.go b/handler.go index d4b1b7f..bc07c19 100644 --- a/handler.go +++ b/handler.go @@ -4,12 +4,13 @@ import ( "crypto/rand" _ "embed" "encoding/base64" + "errors" + "fmt" "html/template" "io" "log" "net/http" "os" - "path" "path/filepath" "runtime" "strconv" @@ -33,6 +34,11 @@ type wasmServer struct { securityToken string } +var wasmLocations = []string{ + "misc/wasm/wasm_exec.js", + "lib/wasm/wasm_exec.js", +} + func NewWASMServer(wasmFile string, args []string, coverageFile string, l *log.Logger) (http.Handler, error) { var err error srv := &wasmServer{ @@ -55,8 +61,23 @@ func NewWASMServer(wasmFile string, args []string, coverageFile string, l *log.L srv.envMap[vars[0]] = vars[1] } - buf, err := os.ReadFile(path.Join(runtime.GOROOT(), "misc/wasm/wasm_exec.js")) + var buf []byte + for _, loc := range wasmLocations { + buf, err = os.ReadFile(filepath.Join(runtime.GOROOT(), loc)) + if err == nil { + break + } + if !os.IsNotExist(err) { + return nil, err + } + } if err != nil { + var perr *os.PathError + if errors.As(err, &perr) { + if strings.Contains(perr.Path, filepath.Join("golang.org", "toolchain")) { + return nil, fmt.Errorf("The Go toolchain does not include the WebAssembly exec helper before Go 1.24. Please copy wasm_exec.js to %s", filepath.Join(runtime.GOROOT(), "misc", "wasm", "wasm_exec.js")) + } + } return nil, err } srv.wasmExecJS = buf