这个教程将一步一步指导你将一个简单的程序编译成 WebAssembly。
想要编译成WebAssembly,你首先需要先编译 LLVM。这是运行后续工具的先决条件。
apt-get
或 brew
来安装。如果是 Windows 系统,你可以点击这里。安装完毕后,确认 git
,cmake
和 python
已经在你的环境变量里,可以使用。
通过 Emscripten SDK 构建 Emscripten 是自动的,下面是步骤。
$ git clone https://github.com/juj/emsdk.git
$ cd emsdk
$ ./emsdk install sdk-incoming-64bit binaryen-master-64bit
$ ./emsdk activate sdk-incoming-64bit binaryen-master-64bit
这些步骤完成以后,安装完成。将 Emscripten 的环境变量配置到当前的命令行窗口下。
$ source ./emsdk_env.sh
这条命令将相关的环境变量和目录入口将会配置在当前的命令行窗口中。
在 Windows中,./emsdk
使用 emsdk
代替,source ./emsdk_env.sh
使用 emsdk_env
代替。
现在,我们已经有了一个完整的工具链,将简单的程序编译成 WebAssembly。不过,这里有一些值得提醒的地方:
emcc
命令时,要带着 -s WASM=1
参数(不然,默认将会编译成asm.js)。.html
后缀名。file
协议的。我们需要将我们的输出文件运行在HTTP协议上。下面这些命令可能让你创建一个简单的“hello word”程序,并且编译它。
$ mkdir hello $ cd hello $ echo '#include <stdio.h>' > hello.c $ echo 'int main(int argc, char ** argv) {' >> hello.c $ echo 'printf("Hello, world!\n");' >> hello.c $ echo '}' >> hello.c $ emcc hello.c -s WASM=1 -o hello.html
我们可以使用 emrun
命令来创建一个 http 协议的 web server 来展示我们编译后的文件。
$ emrun --no_browser --port 8080 .
HTTP 服务开启后,您可以在浏览器中打开。如果你看到了“Hello,word!”输出到了 Emscripten 的 控制面板,恭喜你!你的 WebAssembly 程序编译成功了!