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

相关推荐
井柏然19 小时前
从 Monorepo 重温 ESM 的模块化机制
前端·javascript·前端工程化
晓得迷路了19 小时前
栗子前端技术周刊第 102 期 - Vite+ 正式发布、React Native 0.82、Nitro v3 alpha 版...
前端·javascript·vite
XXX-X-XXJ19 小时前
Vue Router完全指南 —— 从基础配置到权限控制
前端·javascript·vue.js
云和数据.ChenGuang19 小时前
vue钩子函数调用问题
前端·javascript·vue.js
鹏多多19 小时前
React动画方案对比:CSS动画和Framer Motion和React Spring
前端·javascript·react.js
亿元程序员19 小时前
8年游戏主程,一篇文章,多少收益?
前端
IT_陈寒20 小时前
5个Java 21新特性实战技巧,让你的代码性能飙升200%!
前端·人工智能·后端
咖啡の猫20 小时前
Vue内置指令与自定义指令
前端·javascript·vue.js
昔人'20 小时前
使用css `focus-visible` 改善用户体验
前端·css·ux
前端双越老师20 小时前
译: 构建高效 AI Agent 智能体
前端·node.js·agent