📝 Add README
This commit is contained in:
parent
5c872efa5c
commit
d4cba7e99d
1 changed files with 72 additions and 0 deletions
72
README.md
Normal file
72
README.md
Normal file
|
|
@ -0,0 +1,72 @@
|
|||
# go-promises
|
||||
|
||||
Return promises from Go WASM.
|
||||
|
||||
## Usage
|
||||
|
||||
Write some go code, like this.
|
||||
|
||||
```go
|
||||
import (
|
||||
"syscall/js"
|
||||
|
||||
promises "codeberg.org/danjones000/go-promises"
|
||||
)
|
||||
|
||||
func Add(a, b int) int {
|
||||
return a + b
|
||||
}
|
||||
|
||||
func AddWrapper() value.JSWrapper {
|
||||
return func(this js.Value, args []js.Value) (any, error) {
|
||||
if len(args) < 2 {
|
||||
return nil, errors.New("add called with too few arguments")
|
||||
}
|
||||
a := args[0]
|
||||
b := args[1]
|
||||
|
||||
if a.Type() != js.TypeNumber {
|
||||
return nil, fmt.Errorf("First argument must be a number. %s given", a.Type())
|
||||
}
|
||||
|
||||
if b.Type() != js.TypeNumber {
|
||||
return nil, fmt.Errorf("secong argument must be a number. %s given", b.Type())
|
||||
}
|
||||
|
||||
return Add(a.Int(), b.Int()), nil
|
||||
}
|
||||
}
|
||||
|
||||
func main() {
|
||||
js.Global().Set("add", promises.PromisifyGoFunc(AddWrapper()))
|
||||
<-make(chan struct{})
|
||||
}
|
||||
```
|
||||
|
||||
Next, compile this code:
|
||||
|
||||
```shell
|
||||
GOOS=js GOARCH=wasm go build -o ./app.wasm ./
|
||||
```
|
||||
|
||||
Copy the `app.wasm` file, as well as the `wasm_exec.js` from your go installation, into wherever you have your web files located.
|
||||
|
||||
```shell
|
||||
cp app.wasm "$(go env GOROOT)"/misc/wasm/wasm_exec.js path/to/web/
|
||||
```
|
||||
|
||||
Finally, you'll need some frontend code like this:
|
||||
|
||||
```javascript
|
||||
const go = new Go();
|
||||
WebAssembly.instantiateStreaming(fetch("app.wasm"), go.importObject).then((result) => {
|
||||
go.run(result.instance);
|
||||
});
|
||||
```
|
||||
|
||||
Now, the "add" function is available anywhere in your javascript.
|
||||
|
||||
## Roadmap
|
||||
|
||||
- [ ] Argument validation, so you can write less code in your wrapper function.
|
||||
- [ ] An easy method for attaching functions to other objects, so they don't have to be in the global scope
|
||||
Loading…
Add table
Add a link
Reference in a new issue