WebAssembly - конвертировать WAT в WASM

В предыдущей главе мы увидели, как писать код на .watт.е. текстовый формат WebAssembly. Текстовый формат WebAssembly не будет работать напрямую в браузере, и вам необходимо преобразовать его в двоичный формат, то есть WASM, чтобы работать в браузере.

WAT в WASM

Давайте конвертируем .WAT в .WASM.

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

(module 
   (func $add (param $a i32) (param $b i32) (result i32) 
      get_local $a 
      get_local $b 
      i32.add
   ) 
   (export "add" (func $add)) 
)

Теперь перейдите к WebAssembly Studio, который доступен по адресу https://webassembly.studio/.

Вы должны увидеть что-то вроде этого, когда нажмете ссылку -

Щелкните Пустой проект Wat и нажмите кнопку Создать внизу.

Это приведет вас к пустому проекту, как показано ниже -

Щелкните main.wat, замените существующий код своим и нажмите кнопку сохранения.

После сохранения щелкните сборку, чтобы преобразовать ее в .wasm -

Если сборка прошла успешно, вы должны увидеть файл .wasm, созданный, как показано ниже -

Откройте файл main.wasm и используйте его внутри своего .html файла, чтобы увидеть результат, как показано ниже.

Например - add.html

<!doctype html>
<html>
   <head>
      <meta charset="utf-8">
      <title>WebAssembly Add Function</title>
   </head>
   <body>
      <script> 
         let sum; 
         fetch("main.wasm")
            .then(bytes => bytes.arrayBuffer()) 
            .then(mod => WebAssembly.compile(mod)) .then(module => {
            
            return new WebAssembly.Instance(module) 
         })
         .then(instance => {
            sum = instance.exports.add(10,40); 
            console.log("The sum of 10 and 40 = " +sum); 
         }); 
      </script>
   </body>
</html>

Функция add экспортируется, как показано в коде. Переданные параметры - это 2 целых числа 10 и 40, и он возвращает их сумму.

Вывод

Результат отображается в браузере.