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.