WebAssembly - Работа с Rust

Чтобы получить код компиляции RUST, мы воспользуемся инструментом WebAssembly.studio.

Перейдите в WebAssembly.studio, который доступен по адресу Перейти кhttps://webassembly.studio/ и он отобразит вам экран, как показано ниже -

Щелкните «Пустой проект Rust». После этого вы получите три файла в папке src / -

Откройте файл main.rs и измените код по вашему выбору.

Я добавляю следующую функцию, которая добавит два заданных числа -

fn add_ints(lhs: i32, rhs: i32) -> i32 {
   lhs+rhs
}

Код, доступный в main.rs, выглядит следующим образом:

#[no_mangle]
pub extern "C" fn add_one(x: i32) -> i32 {
   x + 1
}

Замените fn add_one своим, как показано ниже -

#[no_mangle]
pub extern "C" fn add_ints(lhs: i32, rhs: i32) -> i32 {
   lhs+rhs
}

В main.js измените имя функции с add_one на add_ints

fetch('../out/main.wasm').then(
   response =>
   response.arrayBuffer()
).then(bytes => WebAssembly.instantiate(bytes)).then(results => {
   instance = results.instance;
   document.getElementById("container").textContent = instance.exports.add_one(41);
}).catch(console.error);

Заменить instance.exports.add_one на instance.exports.add_ints (100,100)

fetch('../out/main.wasm').then(
   response =>
   response.arrayBuffer()
).then(bytes => WebAssembly.instantiate(bytes)).then(results => {
   instance = results.instance;
   document.getElementById("container").textContent = instance.exports.add_ints(100,100)
}).catch(console.error);

Нажмите кнопку сборки, доступную в пользовательском интерфейсе webassembly.studio, чтобы построить код.

После завершения сборки нажмите кнопку «Выполнить», доступную в пользовательском интерфейсе, чтобы увидеть результат -

Мы получаем результат как 200, поскольку мы передали instance.exports.add_ints (100,100).

Точно так же вы можете написать другую программу для rust и скомпилировать ее в webassembly.studio.