WebAssembly - Отладка WASM в Firefox

Поддержка WebAssembly добавлена ​​во все современные браузеры, такие как Chrome, Firefox. Версия Firefox 54+ и более поздняя предоставляет вам специальную функцию для отладки кода wasm.

Для этого выполните свой код в браузерах Firefox, которые вызывают wasm. Например, рассмотрите следующий код C, который находит квадрат числа.

Пример для программы C выглядит следующим образом -

#include<stdio.h>
int square(int n) {
   return n*n;
}

Мы воспользуемся WASM explorer, чтобы получить код wasm -

Загрузите код WASM и используйте его для просмотра результатов в браузере.

Файл html, загружающий wasm, выглядит следующим образом:

!doctype html> 
<html>
   <head>
      <meta charset="utf-8"> 
      <title>WebAssembly Square function</title> 
      <style> 
         div { 
            font-size : 30px; text-align : center; color:orange; 
         } 
      </style> 
   </head> 
   <body> 
      <div id="textcontent"></div> 
      <script> 
         let square; 
         fetch("findsquare.wasm").then(bytes => bytes.arrayBuffer()) 
            .then(mod => WebAssembly.compile(mod)) 
            .then(module => {return new WebAssembly.Instance(module) }) 
            .then(instance => {  
            square = instance.exports.square(13);
            console.log("The square of 13 = " +square);           
            document.getElementById("textcontent").innerHTML = "The square of 13 = " +square; 
         }); 
      </script> 
   </body> 
</html>

Откройте браузер Firefox, загрузите указанный выше html-файл и откройте инструмент отладчика.

Вы должны увидеть запись wasm: // в инструменте отладчика. Щелкните wasm: //, и он покажет код wasm, преобразованный в формат .wat, как показано выше.

Вы можете взглянуть на код экспортированной функции и отладить его, если возникнет какая-либо проблема. Firefox также намеревается добавить точки останова, чтобы вы могли отлаживать код и проверять поток выполнения.