0510252385
Former-commit-id: ff953ca879339fe1e1211f7220f563e1342e66cb
3.7 KiB
3.7 KiB
Build WebAssembly
Build WebAssembly on Windows
- Install Emscripten by following the instructions here.
- Follow the instructions here to update Emscripten to the latest version.
- Install Firefox (for testing).
- Get CoreRT set up by following the Visual Studio instructions.
- Build the WebAssembly runtime by running
build.cmd wasm
from the repo root. - Run the WebAssembly "Hello World" test by running
C:\corert\tests\runtest.cmd wasm
.
Build WebAssembly on OSX
- Install Emscripten by following the instructions here.
- Follow the instructions here to update Emscripten to the latest version.
- Get CoreRT set up by installing Prerequisites.
- Build the WebAssembly runtime by running
./build.sh wasm
from the repo root. - Run the WebAssembly "Hello World" test by opening it in Firefox.
Build WebAssembly on Ubuntu 16.04.3
- Get CoreRT set up by installing Prerequisites, except install
libicu55
for Ubuntu 16 instead oflibicu52
. - Install Emscripten by following the instructions here.
- Follow the instructions here to update Emscripten to the latest version.
- Build the WebAssembly runtime by running
./build.sh wasm
from the repo root. - Run the WebAssembly "Hello World" test by opening it in Firefox.
How to debug the IL->WebAssembly compilation
This is Windows only for now.
- Set the ILCompiler startup command line to
@C:\corert\tests\src\Simple\HelloWasm\obj\Debug\wasm\native\HelloWasm.ilc.rsp
. That will generate HelloWasm.bc, an LLVM bitcode file. - To compile that to WebAssembly, run
emcc HelloWasm.bc -s ALLOW_MEMORY_GROWTH=1 C:\corert\bin\WebAssembly.wasm.Debug\sdk\libPortableRuntime.bc C:\corert\bin\WebAssembly.wasm.Debug\sdk\libbootstrappercpp.bc -s WASM=1 -o HelloWasm.html
(if emcc isn't on your path, you'll need to launch an Emscripten command prompt to do this). That will generate a .wasm file with your code as well as html and js files to run it.
How to run a WebAssembly application
- Ensure you have Edge 41 (Windows only) or above or Firefox.
- Open the generated html file in Edge or Firefox and look at the on-screen console for output.
Useful tips
- To manually make ILC compile to WebAssembly, add
--wasm
to the command line. - To debug C# source, add
-g4
to the emcc command line and change-s WASM=1
to-s WASM=0
. This will generate a JavaScript source map that browser debuggers and Visual Studio Code can work with. Using Visual Studio Code's Chrome debugger works particularly well. - Add
-g3
to the emcc command line to generate more debuggable output and a .wast file with the text form of the WebAssembly. - Change
-s WASM=1
to-s WASM=0
in the emcc command line to generate asm.js. Browser debuggers currently work better with asm.js and it's often a bit more readable than wast. - Add
-O2 --llvm-lto 2
to the emcc command line to enable optimizations. This makes the generated WebAssembly as much as 75% smaller as well as more efficient.