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 模块,并从中获得性能改进。

相关推荐
__sgf__2 分钟前
ES9(ES2018)新特性
前端·javascript
送鱼的老默8 分钟前
学习笔记--vue3 watchEffect监听的各种姿势用法和总结
前端·vue.js
你挚爱的强哥8 分钟前
解决:动态文本和背景色一致导致文字看不清楚,用js获取背景图片主色调,并获取对比度最大的hex色值给文字
前端·javascript·github
用户693717500138416 分钟前
Android 手机终于能当电脑用了
android·前端
wooyoo17 分钟前
花了一周 vibe 了一个 OpenClaw 的 Agent 市场,聊聊过程中踩的坑
前端·后端·agent
angerdream20 分钟前
最新版vue3+TypeScript开发入门到实战教程之路由详解
前端·javascript·vue.js
送鱼的老默25 分钟前
学习笔记--vue3 watch监听的各种姿势用法和总结
前端·vue.js
猪八宅百炼成仙1 小时前
解决 el-date-picker type:daterange 在 layout 布局中的宽度问题
前端·element
小贺要学前端1 小时前
ES6 还没用明白,JavaScript 已经快到 ES2026 了
前端·javascript·es6
Amumu121381 小时前
JS:ES6~ES11基础语法(二)
开发语言·前端·javascript