WebAssembly.Exception.prototype.getArg()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since May 2022.
The getArg()
prototype method of the Exception
object can be used to get the value of a specified item in the exception's data arguments.
The method passes a WebAssembly.Tag
and will only succeed if the thrown Exception
was created using the same tag, otherwise it will throw a TypeError
.
This ensures that the exception can only be read if the calling code has access to the tag.
Tags that are neither imported into or exported from the WebAssembly code are internal, and their associated WebAssembly.Exception
cannot be queried using this method!
Note: It is not enough that the tag has an identical sequence of data types — it must have the same identity (be the same tag) as was used to create the exception.
Syntax
getArg(exceptionTag, index)
Parameters
exceptionTag
-
A
WebAssembly.Tag
that must match the tag associated with this exception. index
-
The index of the value in the data arguments to return, 0-indexed.
Return value
The value of the argument at index
.
Exceptions
TypeError
-
The tags don't match; the exception was not created with the tag passed to the method.
RangeError
-
The value of the
index
parameter is greater than or equal to the number of fields in the data.
Examples
In order to get the values of an exception, the tag must be "known" to the calling code; it may be either imported into or exported from the calling code.
Getting exception value from imported tag
Consider the following WebAssembly code, which is assumed to be compiled to a file "example.wasm".
This imports a tag, which it refers to internally as $tagname
, and exports a method run
that can be called by external code to throw an exception using the tag.
(module
;; import tag that will be referred to here as $tagname
(import "extmod" "exttag" (tag $tagname (param i32)))
;; $throwException function throws i32 param as a $tagname exception
(func $throwException (param i32)
local.get 0
throw $tagname
)
;; Exported function "run" that calls $throwException
(func (export "run")
i32.const 1
call $throwException
)
)
The code below calls WebAssembly.instantiateStreaming
to import the "example.wasm" file, passing in an "import object" (importObject
) that includes a new WebAssembly.Tag
named tagToImport
.
The import object defines an object with properties that match the import
statement in the WebAssembly code.
Once the file is instantiated, the code calls the exported WebAssembly run()
method, which will immediately throw an exception.
const tagToImport = new WebAssembly.Tag({ parameters: ["i32"] });
// Note: the import object properties match the import statement in WebAssembly code!
const importObject = {
extmod: {
exttag: tagToImport,
},
};
WebAssembly.instantiateStreaming(fetch("example.wasm"), importObject)
.then((obj) => {
console.log(obj.instance.exports.run());
})
.catch((e) => {
console.error(e);
console.log(`getArg 0 : ${e.getArg(tagToImport, 0)}`);
});
/* Log output
example.js:40 WebAssembly.Exception: wasm exception
example.js:41 getArg 0 : 1
*/
The code catches the exception and uses getArg()
to print the value at the first index.
In this case, it is just "1".
Getting exception value from an exported tag
The process for using an exported tag is very similar to that shown in the previous section. Here is the same WebAssembly module, simply replacing the import with an export.
(module
;; Export tag giving it external name: "exptag"
(tag $tagname (export "exptag") (param i32))
(func $throwException (param i32)
local.get 0
throw $tagname
)
(func (export "run")
i32.const 1
call $throwException
)
)
The JavaScript is similar too. In this case, we have no imports, but instead we get the exported tag and use that to get the argument.
To make it a little more "safe", here we also test that we have the right tag using the is()
method.
let tagExportedFromWasm;
WebAssembly.instantiateStreaming(fetch("example.wasm"))
.then((obj) => {
// Import the tag using its name from the WebAssembly module
tagExportedFromWasm = obj.instance.exports.exptag;
console.log(obj.instance.exports.run());
})
.catch((e) => {
console.error(e);
// If the tag is correct, get the value
if (e.is(tagExportedFromWasm)) {
console.log(`getArg 0 : ${e.getArg(tagExportedFromWasm, 0)}`);
}
});
Specifications
Specification |
---|
WebAssembly JavaScript Interface: Exception Handling # dom-exception-getarg |
Browser compatibility
BCD tables only load in the browser