Skip to content

Latest commit

 

History

History
111 lines (56 loc) · 4.24 KB

README.md

File metadata and controls

111 lines (56 loc) · 4.24 KB

Emscripten Build System for WASM + JS

Install Emscripten Core SDK

In your shell of choice, navigate to the emsdk directory and run the following commands:

git clone https://github.com/emscripten-core/emsdk.git

./emsdk install latest

./emsdk install activate || ./emsdk install activate --permanent

Run ./emsdk help for more information.

See https://emscripten.org/docs/tools_reference/emsdk.html#command-line-syntax for full emsdk command list.

Get Started with Emscripten Compiler

Emscripten is a compiler that allows you to compile code from any LLVM based language to WebAssembly Binary by being tightly coupled with LLVM, Clang, Binaryen, and Closure Compiler.

emcc hello.c -o out.js

node out.js

See https://emscripten.org/docs/getting_started/Tutorial.html#running-emscripten for more detail.

Start Building or Running Examples

To start with examples:

Run using VSCode's Live Server or any other server, to serve the HTML file at the root. It contains all examples served from the build folder. Uncomment the script you want to run in the HTML file.

To build from source folders:

Mac / Linux / Windows: bash build.sh

Note: Not all scripts are included. Some may be specific to your OS.

Grab Wasmtime:

Mac / Linux: curl https://wasmtime.dev/install.sh -sSf | bash

Note: If you are using Windows, using Wasmtime to run files requires .msi installation from https://github.com/bytecodealliance/wasmtime/releases.

Note: If you are using Windows, wat2wasm requires the WABT package from https://github.com/WebAssembly/wabt/releases and then ran via cmd. Ensure all path variables are set correctly.

Advanced Usage - Build Libraries for use in seperate files

img

Build Flow PDF

See src/library for all examples.

See src/library/cmake for examples on compiling and including libraries.

Build HTML - embedded only, no direct access to modules.

"buildHTML": "emcc src/gol.cpp -o build/gol.html"

See build/gol.html for example.

Note: It is recommended to pass optimization flags (O1-O3) and MINIFY_HTML=1 to reduce the size of the output.

"buildHTML": "emcc src/gol.cpp -o build/gol.html -O3 -s MINIFY_HTML=1"

Build JS - embeddable, access module via Module.isRuntimeInitialized

See build/gol.js for example - https://webassembly.github.io/spec/js-api/#sample

"buildAccessor": "emcc -o build/gol.js src/gol.cpp -s EXPORTED_RUNTIME_METHODS=['ccall'] -s EXPORTED_FUNCTIONS=\_main,\_myFunction"

Note: -s USE_CLOSURE_COMPILER=1 and optimization flags like -O1, -O2, -O3 can be used further optimize the output, and are recommended.

Build WASM - standalone & embeddable.

More information about building WASM standalone using emcc, in relation to V8 - https://v8.dev/blog/emscripten-standalone-wasm

Use wasm-dis or wasm2wat to view the binaries in text format. https://github.com/WebAssembly/binaryen/blob/main/src/tools/wasm-dis.cpp

"buildWASM": "emcc src/gol.cpp -o build/gol.wasm -s STANDALONE_WASM=1 -s EXPORTED_FUNCTIONS=[_main,_myFunction]"

"buildSimple": "emcc src/c/simple.c -o build/simple.wasm -s STANDALONE_WASM=1 -s EXPORT_ALL=1"

"buildWAT": "wat2wasm src/wasm/memory.wat -o build/memory.wasm"

Example Vector Math C->JS Library

See /src/js/*.js for examples.

"buildVec": "emcc src/c/vectors.c -o build/vectors.wasm -s STANDALONE_WASM=1 -s EXPORTED_FUNCTIONS=_alloc_vector,_dealloc_vector,_add_vectors,_sub_vectors,_mul_scalar"

Build ASC - AssemblyScript - A TS Variant for WASM

A TypeScript-like language for WebAssembly.

https://www.assemblyscript.org/ uses https://github.com/WebAssembly/binaryen under the hood.

"buildASC": "asc src/ts-asc/fib.ts --outFile build/assembly.wasm --optimize"

Run Standalone WASM - Wasmer or WasmTime - WASI (WebAssembly System Interface)

See the src/wasi directory for more information on WASI.

Build from WAT Only - wat2wasm - WebAssembly Text Format

Use wat2wasm to convert wat text file to wasm binaries. https://github.com/webassembly/wabt / https://github.com/xtuc/webassemblyjs/tree/master/packages/wast-loader

"buildWASMOnly": "wat2wasm src/simple.wat -o build/simple.wasm"

To see more examples, visit https://github.com/emscripten-core/emscripten/wiki/Porting-Examples-and-Demos