Shopify 开源 Ruvy,将 Ruby 代码转换成 WebAssembly

|----|-----------------------------------------------------------------------------------------------|
| 导读 | Shopify 最近开源了一个名为 Ruvy 的项目。Ruvy 是一个工具链,它接受 Ruby 代码作为输入,并创建一个将执行该 Ruby 代码的 WebAssembly 模块。 |

目前已有从 Ruby 代码创建 Wasm 模块的项目,最常见的是 ruby.wasm,Ruvy 也是基于 ruby.wasm 构建,并提供了一些特定的优势。

官方称创建 Ruvy 旨在利用预初始化 Ruby 虚拟机和 Ruby 脚本包含的 Ruby 文件带来的性能改进。此外,Ruvy 不需要在运行时提供 WASI 参数,从而简化了 Wasm 模块的执行。

WASI 是一组导入的 Wasm 函数的标准化集合,旨在为 Wasm 模块提供一个标准接口,以实现许多典型语言标准库中存在的系统调用。

目前,Ruvy 并未随预编译的二进制文件一起发布,因此需要安装它的构建依赖项,然后编译 Ruvy 才能使用。

安装这些依赖项的详细信息请查看 README。

构建 Ruvy 后,可以运行以下命令来打印出 Hello World。

复制代码
$ cargo run -- package=cli ruby_examples / hello_world.rb - o index.wasm 
$ wasmtime index.wasm 
Hello world

上述命令将构建并执行 CLI,首先获取 ruby_examples/hello_world.rb 的内容,并创建一个名为 index.wasm 的 Wasm 模块。当调用 index.wasm 的导出_start 的函数时,将执行 puts "Hello world"。

如果要使用额外的 Ruby 文件,可以运行以下命令:

复制代码
$ cargo run -- package=cli -- -- preload=prelude / ruby_examples / use_preludes_and_stdin.rb 
$ echo "this is my input" | wasmtime index.wasm 
{:discount_input=>"this is my input", :value=>100.0}

这就是 Shopify 新推出 Ruvy 项目的简要介绍。它为 Ruby 开发者提供了一个新工具,使得他们可以更方便地将 Ruby 代码转换为 WebAssembly 模块,并从中获得性能改进。

相关推荐
周亚鑫5 分钟前
vue3 pdf base64转成文件流打开
前端·javascript·pdf
Justinc.21 分钟前
CSS3新增边框属性(五)
前端·css·css3
neter.asia37 分钟前
vue中如何关闭eslint检测?
前端·javascript·vue.js
~甲壳虫38 分钟前
说说webpack中常见的Plugin?解决了什么问题?
前端·webpack·node.js
嚣张农民44 分钟前
JavaScript中Promise分别有哪些函数?
前端·javascript·面试
光影少年1 小时前
vue2与vue3的全局通信插件,如何实现自定义的插件
前端·javascript·vue.js
As977_1 小时前
前端学习Day12 CSS盒子的定位(相对定位篇“附练习”)
前端·css·学习
susu10830189111 小时前
vue3 css的样式如果background没有,如何覆盖有background的样式
前端·css
Ocean☾1 小时前
前端基础-html-注册界面
前端·算法·html
Dragon Wu1 小时前
前端 Canvas 绘画 总结
前端