WebAssembly - "Hello World"

Pada bab ini kita akan menulis program sederhana dalam bahasa C dan mengubahnya menjadi .wasm dan menjalankan program yang sama di browser untuk mendapatkan teks "Hello World".

Akan menggunakan alat penjelajah wasm yang akan mengubah program C menjadi .wasm dan akan menggunakan .wasm di dalam file .html kita.

Alat penjelajah Wasm yang tersedia di https://mbebenita.github.io/WasmExplorer/ looks as follows −

Kode C yang akan kita gunakan adalah sebagai berikut -

#include <stdio.h>
char *c_hello() {
   return "Hello World"; 
}

Perbarui blok pertama di wasm explorer dengan kode C seperti yang ditunjukkan di bawah ini -

Klik pada Tombol SELESAI untuk mengkompilasi ke WASM dan WAT dan Firefox x86 Web Assembly seperti yang ditunjukkan di bawah ini -

Gunakan UNDUH untuk mendapatkan file .wasm dan simpan sebagai firstprog.wasm.

Buat file .html bernama firstprog.html seperti yang ditunjukkan di bawah ini -

<!doctype html>
<html>
   <head>
      <meta charset="utf-8"> 
      <title>WebAssembly Hello World</title> 
   </head> 
   <body>
      <div id="textcontent"></div>     
      <script type="text/javascript"> 
         //Your code from webassembly here
      </script> 
   </body>
</html>

Mari kita sekarang menggunakan firstprog.wasm untuk membaca helloworld dari fungsi C c_hello ().

Langkah 1

Gunakan fetch () api untuk membaca kode firstprog.wasm.

Langkah 2

Kode .wasm harus diubah menjadi arraybuffer dengan menggunakan ArrayBuffer. Objek ArrayBuffer akan mengembalikan Anda buffer data biner dengan panjang tetap.

Kode sejauh ini adalah sebagai berikut -

<script type="text/javascript"> 
   fetch("firstprog.wasm") .then(bytes => bytes.arrayBuffer()) 
</script>

LANGKAH 3

Byte dari ArrayBuffer harus dikompilasi menjadi modul dengan menggunakan WebAssembly.compile(buffer) fungsi.

Kode akan terlihat seperti di bawah ini -

<script type="text/javascript">
   fetch("firstprog.wasm")
   .then(bytes => bytes.arrayBuffer())
   .then(mod => WebAssembly.compile(mod))
</script>

LANGKAH 4

Untuk mendapatkan modul kita harus memanggil konstruktor webassembly.instance seperti yang ditunjukkan di bawah ini -

<script type="text/javascript">     
   fetch("firstprog.wasm") 
   .then(bytes => bytes.arrayBuffer())
   .then(mod => WebAssembly.compile(mod))
   .then(module => {return new WebAssembly.Instance(module) }) 
</script>

LANGKAH 5

Sekarang mari kita konsol instance tersebut untuk melihat detailnya di browser.

<script type="text/javascript"> 
   fetch("firstprog.wasm") .then(bytes => bytes.arrayBuffer()) 
   .then(mod => WebAssembly.compile(mod)) .then(module => {
      return new WebAssembly.Instance(module) 
   }) 
   .then(instance => {
      console.log(instance);
   }); 
</script>

Detail console.log ditunjukkan di bawah ini -

Untuk mendapatkan string “Hello World” dari fungsi c_hello (), kita perlu menambahkan beberapa kode di javascript.

Pertama, dapatkan detail buffer memori seperti yang ditunjukkan di bawah ini -

let buffer = instance.exports.memory.buffer;;

Nilai buffer harus dikonversi ke array yang diketik sehingga kita dapat membaca nilai darinya. Buffer memiliki string Hello World di dalamnya.

Untuk mengonversi ke panggilan yang diketik, konstruktor Uint8Array seperti yang ditunjukkan di bawah ini -

let buffer = new Uint8Array(instance.exports.memory.buffer);

Sekarang, kita dapat membaca nilai dari buffer dalam for - loop.

Mari kita sekarang mendapatkan titik awal untuk membaca buffer, dengan memanggil fungsi yang kita tulis seperti yang ditunjukkan di bawah ini -

let test = instance.exports.c_hello();

Sekarang, variabel uji memiliki titik awal untuk membaca string kita. WebAssembly tidak memiliki apa pun untuk nilai string, semuanya disimpan sebagai integer.

Jadi ketika kita membaca nilai dari buffer, itu akan menjadi nilai integer dan kita perlu mengubahnya menjadi string menggunakan fromCharCode () di javascript.

Kodenya adalah sebagai berikut -

let mytext = ""; 
for (let i=test; buffer[i]; i++){ 
   mytext += String.fromCharCode(buffer[i]);
}

Sekarang, ketika Anda konsol mytext Anda akan melihat string "Hello World".

Contoh

Kode lengkapnya adalah sebagai berikut -

<!doctype html> 
<html> 
   <head> 
      <meta charset="utf-8"> 
      <title>WebAssembly Add Function</title>
      <style>
         div { 
            font-size : 30px; text-align : center; color:orange; 
         } 
      </style>
   </head>
   <body>
      <div id="textcontent"></div>
      <script> 
         fetch("firstprog.wasm")
         .then(bytes => bytes.arrayBuffer())
         .then(mod => WebAssembly.compile(mod))
         .then(module => {return new WebAssembly.Instance(module)})
         .then(instance => {   
            console.log(instance); 
            let buffer = new Uint8Array(instance.exports.memory.buffer); 
            let test = instance.exports.c_hello(); 
            let mytext = ""; 
            for (let i=test; buffer[i]; i++) {
               mytext += String.fromCharCode(buffer[i]);
            }
            console.log(mytext); document.getElementById("textcontent").innerHTML = mytext; 
         });
      </script>
   </body>
</html>

Kami telah menambahkan div dan isinya ditambahkan ke div, sehingga string ditampilkan di browser.

Keluaran

Outputnya disebutkan di bawah ini -