生成wasm

V编译器支持wasm后端,将V源代码编译生成wasm代码。

安装依赖

当第一次运行 v -b wasm xxx.v时,编译器会提示,缺少外部依赖库binaryen,需要先执行脚本下载对应平台的预编译版本。安装脚本会下载并解压到path_to_v/thirdparty/binaryen目录中。

path_to_v/cmd/tools/install_binaryen.vsh

也可以直接下载binaryen源代码,自行编译,编译步骤如下:

git clone https://github.com/WebAssembly/binaryen.git
git submodule init
git submodule update
cmake . && make #需要提前安装好cmake
make install

编译目标系统

v -b wasm -os wasi #编译为符合wasi标准的代码,不特别指定-os选项值,默认是wasi
v -b wasm -os browser #编译为浏览器环境的代码

示例代码:

mandelbrot.v

fn JS.canvas_x() int
fn JS.canvas_y() int
fn JS.setpixel(x int, y int, c f64)

// `main` must be public!
pub fn main() {
	max_x := JS.canvas_x()
	max_y := JS.canvas_y()

	println('starting main.main!')

	mut y := 0
	for y < max_y {
		y += 1
		mut x := 0
		for x < max_x {
			x += 1

			e := (f64(y) / 50) - 1.5
			f := (f64(x) / 50) - 1.0

			mut a := 0.0
			mut b := 0.0
			mut i := 0.0
			mut j := 0.0
			mut c := 0.0

			for i * i + j * j < 4 && c < 255 {
				i = a * a - b * b + e
				j = 2 * a * b + f
				a = i
				b = j
				c += 1
			}

			JS.setpixel(x, y, c)
		}
	}

	panic('reached the end!')
}

mandelbrot.html

编译生成wasm文件:

就可以打开mandelbrot.html运行wasm文件。

最后更新于

这有帮助吗?