wat2js

Compile WebAssembly .wat files to a common js module

  • 所有者: mafintosh/wat2js
  • 平台:
  • 許可證: MIT License
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

wat2js

Compile WebAssembly .wat files to a common js module

npm install -g wat2js

See https://github.com/WebAssembly/wabt for more WebAssembly goodies.

Currently requires the wat2wasm program to be installed globally. If you don't have that already you can get that by installing the webassembly binary toolkit by using this little helper

Usage

First make a basic WebAssembly .wat file

;; example.wat
(module
  ;; var result = add(a, b)
  (func (export "add") (param $a i32) (param $b i32) (result i32)
    ;; return a + b
    (i32.add
      (get_local $a)
      (get_local $b)
    )
  )
)

Then compile it to WebAssembly and wrap in a common js loader by doing

wat2js example.wat -o example.js

To run the WebAssembly simply do:

var example = require('./example.js')() // load the wasm
if (!example) throw new Error('WebAssembly not supported by your runtime')

var result = example.exports.add(1, 2)
console.log('1 + 2 = ' + result)

To keep recompiling the .wat file when it changes pass the --watch option as well

wat2js example.wat -o example.js --watch # recompile when example.wat changes

You can also pass arguments to wat2wasm:

wat2js example.wat -o example.js --watch -- --debug-names # add debug names section

API

var mod = require('./compiled-wat.js')([options])

Loads your WebAssembly module. If WebAssembly is not supported by the runtime, null is returned.

Options include:

{
  imports: {...} // import objected forwared to WASM,
  async: true // force async loading.
}

Note that if your WASM is larger than 4kb, some browsers might force async loading.

mod looks like this

{
  exports: {...}, // exports WASM functions
  memory: Uint8Array, // exports.memory wrapped in a uint8array (if exported)
  buffer: Uint8Array, // the WASM module as a buffer
  onload: onload(cb), // function you can call to wait for async loading
  realloc: realloc(bytes) // reallocate the memory buffer to a new size
}

In case of async loading exports and memory will be null until the module has been loaded.

License

MIT

主要指標

概覽
名稱與所有者mafintosh/wat2js
主編程語言JavaScript
編程語言JavaScript (語言數: 2)
平台
許可證MIT License
所有者活动
創建於2017-06-26 11:03:19
推送於2020-01-09 21:11:44
最后一次提交2018-11-07 16:46:34
發布數7
最新版本名稱v2.1.1 (發布於 2018-11-07 16:46:34)
第一版名稱v1.0.0 (發布於 2017-06-26 13:03:37)
用户参与
星數135
關注者數8
派生數24
提交數18
已啟用問題?
問題數2
打開的問題數1
拉請求數2
打開的拉請求數2
關閉的拉請求數1
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?