WebAssembly - "हैलो वर्ल्ड"
इस अध्याय में हम C में एक सरल प्रोग्राम लिखने जा रहे हैं और इसे .wasm में रूपांतरित करते हैं और "हैलो वर्ल्ड" पाठ प्राप्त करने के लिए ब्राउज़र में इसे निष्पादित करते हैं।
Wasm एक्सप्लोरर टूल का उपयोग करेगा जो C प्रोग्राम को .wasm में बदल देगा और हमारे .html फ़ाइल के अंदर .wasm का उपयोग करेगा।
वासम एक्सप्लोरर उपकरण जो पर उपलब्ध है https://mbebenita.github.io/WasmExplorer/ looks as follows −
C कोड जो हम उपयोग करने जा रहे हैं वह इस प्रकार है -
#include <stdio.h>
char *c_hello() {
return "Hello World";
}
नीचे दिखाए गए अनुसार C कोड के साथ wasm एक्सप्लोरर में पहला ब्लॉक अपडेट करें -
नीचे दिखाए गए अनुसार WASM और WAT और Firefox x86 वेब असेंबली के संकलन के लिए कंपाइल बटन पर क्लिक करें -
.Wasm फ़ाइल प्राप्त करने के लिए DOWNLOAD का उपयोग करें और इसे इस रूप में सहेजें firstprog.wasm।
नीचे दिखाए अनुसार firstprog.html नामक एक .html फ़ाइल बनाएँ -
<!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>
आइए अब C फ़ंक्शन c_hello () से Helloworld को पढ़ने के लिए firstprog.wasm का उपयोग करें।
चरण 1
Firstprog.wasm कोड पढ़ने के लिए fetch () एपीआई का उपयोग करें।
चरण 2
.Wasm कोड का उपयोग करके arraybuffer में परिवर्तित किया जाना है ArrayBuffer। ArrayBuffer ऑब्जेक्ट आपको निश्चित लंबाई बाइनरी डेटा बफर लौटाएगा।
अब तक का कोड इस प्रकार होगा -
<script type="text/javascript">
fetch("firstprog.wasm") .then(bytes => bytes.arrayBuffer())
</script>
चरण 3
ArrayBuffer से बाइट्स का उपयोग करके एक मॉड्यूल में संकलित किया जाना है WebAssembly.compile(buffer) समारोह।
कोड नीचे की तरह दिखेगा -
<script type="text/javascript">
fetch("firstprog.wasm")
.then(bytes => bytes.arrayBuffer())
.then(mod => WebAssembly.compile(mod))
</script>
चरण 4
मॉड्यूल प्राप्त करने के लिए हमें webassembly.instance कंस्ट्रक्टर को कॉल करना होगा जैसा कि नीचे दिखाया गया है -
<script type="text/javascript">
fetch("firstprog.wasm")
.then(bytes => bytes.arrayBuffer())
.then(mod => WebAssembly.compile(mod))
.then(module => {return new WebAssembly.Instance(module) })
</script>
चरण 5
आइए अब हम ब्राउज़र में विवरण देखने के लिए उदाहरण को सांत्वना देते हैं।
<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>
कंसोल.लॉग विवरण नीचे दिखाए गए हैं -
फ़ंक्शन c_hello () से स्ट्रिंग "हैलो वर्ल्ड" प्राप्त करने के लिए, हमें जावास्क्रिप्ट में कुछ कोड जोड़ना होगा।
सबसे पहले, नीचे दिखाए अनुसार मेमोरी बफर विवरण प्राप्त करें -
let buffer = instance.exports.memory.buffer;;
बफ़र मान को एक टाइप किए गए ऐरे में बदलना होगा ताकि हम इससे प्राप्त मानों को पढ़ सकें। बफर में हैल्लो वर्ल्ड है।
नीचे दिए गए अनुसार टाइप किए गए कॉल को कंस्ट्रक्टर Uint8Array में बदलने के लिए -
let buffer = new Uint8Array(instance.exports.memory.buffer);
अब, हम बफर से मूल्य के लिए एक लूप में पढ़ सकते हैं।
आइए अब हम नीचे दिखाए गए फ़ंक्शन को कॉल करके बफर को पढ़ने के लिए शुरुआती बिंदु प्राप्त करते हैं -
let test = instance.exports.c_hello();
अब, परीक्षण चर में हमारे स्ट्रिंग को पढ़ने के लिए प्रारंभ बिंदु है। WebAssembly में स्ट्रिंग मानों के लिए कुछ भी नहीं है, सब कुछ पूर्णांक के रूप में संग्रहीत किया जाता है।
इसलिए, जब हम बफर से मान को पढ़ते हैं, तो वे पूर्णांक मान होंगे और हमें जावास्क्रिप्ट में इसेCCCode () का उपयोग करके एक स्ट्रिंग में बदलने की आवश्यकता है।
कोड इस प्रकार है -
let mytext = "";
for (let i=test; buffer[i]; i++){
mytext += String.fromCharCode(buffer[i]);
}
अब, जब आप mytext को सांत्वना देते हैं तो आपको स्ट्रिंग "हैलो वर्ल्ड" देखना चाहिए।
उदाहरण
पूरा कोड इस प्रकार है -
<!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>
हमने एक div जोड़ा है और div पर सामग्री जोड़ी है, इसलिए स्ट्रिंग ब्राउज़र पर प्रदर्शित होती है।
उत्पादन
उत्पादन का उल्लेख नीचे दिया गया है -