# Bazel Emscripten toolchain ## Setup Instructions In `WORKSPACE` file, put: ``` load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive") http_archive( name = "emsdk", sha256 = "d55e3c73fc4f8d1fecb7aabe548de86bdb55080fe6b12ce593d63b8bade54567", strip_prefix = "emsdk-3891e7b04bf8cbb3bc62758e9c575ae096a9a518/bazel", url = "https://github.com/emscripten-core/emsdk/archive/3891e7b04bf8cbb3bc62758e9c575ae096a9a518.tar.gz", ) load("@emsdk//:deps.bzl", emsdk_deps = "deps") emsdk_deps() load("@emsdk//:emscripten_deps.bzl", emsdk_emscripten_deps = "emscripten_deps") emsdk_emscripten_deps(emscripten_version = "2.0.31") ``` The SHA1 hash in the above `strip_prefix` and `url` parameters correspond to the git revision of [emsdk 2.0.31](https://github.com/emscripten-core/emsdk/releases/tag/2.0.31). To get access to newer versions, you'll need to update those. To make use of older versions, change the parameter of `emsdk_emscripten_deps()`. Supported versions are listed in `revisions.bzl` ## Building ### Using wasm_cc_binary (preferred) First, write a new rule wrapping your `cc_binary`. ``` load("@rules_cc//cc:defs.bzl", "cc_binary") load("@emsdk//emscripten_toolchain:wasm_rules.bzl", "wasm_cc_binary") cc_binary( name = "hello-world", srcs = ["hello-world.cc"], ) wasm_cc_binary( name = "hello-world-wasm", cc_target = ":hello-world", ) ``` Now you can run `bazel build :hello-world-wasm`. The result of this build will be the individual files produced by emscripten. Note that some of these files may be empty. This is because bazel has no concept of optional outputs for rules. `wasm_cc_binary` uses transition to use emscripten toolchain on `cc_target` and all of its dependencies, and does not require amending `.bazelrc`. This is the preferred way, since it also unpacks the resulting tarball. See `test_external/` for an example using [embind](https://emscripten.org/docs/porting/connecting_cpp_and_javascript/embind.html). ### Using --config=wasm Put the following lines into your `.bazelrc`: ``` build:wasm --crosstool_top=@emsdk//emscripten_toolchain:everything build:wasm --cpu=wasm build:wasm --host_crosstool_top=@bazel_tools//tools/cpp:toolchain ``` Simply pass `--config=wasm` when building a normal `cc_binary`. The result of this build will be a tar archive containing any files produced by emscripten. See the [Bazel documentation](https://docs.bazel.build/versions/main/tutorial/cc-toolchain-config.html) for more details