summaryrefslogtreecommitdiff
path: root/Tests
diff options
context:
space:
mode:
authorIdan Horowitz <idan.horowitz@gmail.com>2021-10-31 17:05:15 +0200
committerIdan Horowitz <idan.horowitz@gmail.com>2021-10-31 18:20:37 +0200
commit10b93506ad0f075b024b5b7172f664296abbc035 (patch)
tree606b7af51f38c41f632156985191f3e6c752ffc3 /Tests
parentae510db72c1e895aea4f4cf0101ae27eaad8f06f (diff)
downloadserenity-10b93506ad0f075b024b5b7172f664296abbc035.zip
Tests: Convert test-wasm functions to ThrowCompletionOr
Diffstat (limited to 'Tests')
-rw-r--r--Tests/LibWasm/test-wasm.cpp58
1 files changed, 23 insertions, 35 deletions
diff --git a/Tests/LibWasm/test-wasm.cpp b/Tests/LibWasm/test-wasm.cpp
index e9243f8f4d..f761a74243 100644
--- a/Tests/LibWasm/test-wasm.cpp
+++ b/Tests/LibWasm/test-wasm.cpp
@@ -60,8 +60,8 @@ public:
~WebAssemblyModule() override = default;
private:
- JS_DECLARE_OLD_NATIVE_FUNCTION(get_export);
- JS_DECLARE_OLD_NATIVE_FUNCTION(wasm_invoke);
+ JS_DECLARE_NATIVE_FUNCTION(get_export);
+ JS_DECLARE_NATIVE_FUNCTION(wasm_invoke);
static HashMap<Wasm::Linker::Name, Wasm::ExternValue> const& spec_test_namespace()
{
@@ -143,19 +143,17 @@ TESTJS_GLOBAL_FUNCTION(compare_typed_arrays, compareTypedArrays)
void WebAssemblyModule::initialize(JS::GlobalObject& global_object)
{
Base::initialize(global_object);
- define_old_native_function("getExport", get_export, 1, JS::default_attributes);
- define_old_native_function("invoke", wasm_invoke, 1, JS::default_attributes);
+ define_native_function("getExport", get_export, 1, JS::default_attributes);
+ define_native_function("invoke", wasm_invoke, 1, JS::default_attributes);
}
-JS_DEFINE_OLD_NATIVE_FUNCTION(WebAssemblyModule::get_export)
+JS_DEFINE_NATIVE_FUNCTION(WebAssemblyModule::get_export)
{
- auto name = TRY_OR_DISCARD(vm.argument(0).to_string(global_object));
+ auto name = TRY(vm.argument(0).to_string(global_object));
auto this_value = vm.this_value(global_object);
- auto* object = TRY_OR_DISCARD(this_value.to_object(global_object));
- if (!is<WebAssemblyModule>(object)) {
- vm.throw_exception<JS::TypeError>(global_object, "Not a WebAssemblyModule");
- return {};
- }
+ auto* object = TRY(this_value.to_object(global_object));
+ if (!is<WebAssemblyModule>(object))
+ return vm.throw_completion<JS::TypeError>(global_object, "Not a WebAssemblyModule");
auto instance = static_cast<WebAssemblyModule*>(object);
for (auto& entry : instance->module_instance().exports()) {
if (entry.name() == name) {
@@ -173,49 +171,41 @@ JS_DEFINE_OLD_NATIVE_FUNCTION(WebAssemblyModule::get_export)
[&](const auto& ref) -> JS::Value { return JS::Value(static_cast<double>(ref.address.value())); });
});
}
- vm.throw_exception<JS::TypeError>(global_object, String::formatted("'{}' does not refer to a function or a global", name));
- return {};
+ return vm.throw_completion<JS::TypeError>(global_object, String::formatted("'{}' does not refer to a function or a global", name));
}
}
- vm.throw_exception<JS::TypeError>(global_object, String::formatted("'{}' could not be found", name));
- return {};
+ return vm.throw_completion<JS::TypeError>(global_object, String::formatted("'{}' could not be found", name));
}
-JS_DEFINE_OLD_NATIVE_FUNCTION(WebAssemblyModule::wasm_invoke)
+JS_DEFINE_NATIVE_FUNCTION(WebAssemblyModule::wasm_invoke)
{
- auto address = static_cast<unsigned long>(TRY_OR_DISCARD(vm.argument(0).to_double(global_object)));
+ auto address = static_cast<unsigned long>(TRY(vm.argument(0).to_double(global_object)));
Wasm::FunctionAddress function_address { address };
auto function_instance = WebAssemblyModule::machine().store().get(function_address);
- if (!function_instance) {
- vm.throw_exception<JS::TypeError>(global_object, "Invalid function address");
- return {};
- }
+ if (!function_instance)
+ return vm.throw_completion<JS::TypeError>(global_object, "Invalid function address");
const Wasm::FunctionType* type { nullptr };
function_instance->visit([&](auto& value) { type = &value.type(); });
- if (!type) {
- vm.throw_exception<JS::TypeError>(global_object, "Invalid function found at given address");
- return {};
- }
+ if (!type)
+ return vm.throw_completion<JS::TypeError>(global_object, "Invalid function found at given address");
Vector<Wasm::Value> arguments;
- if (type->parameters().size() + 1 > vm.argument_count()) {
- vm.throw_exception<JS::TypeError>(global_object, String::formatted("Expected {} arguments for call, but found {}", type->parameters().size() + 1, vm.argument_count()));
- return {};
- }
+ if (type->parameters().size() + 1 > vm.argument_count())
+ return vm.throw_completion<JS::TypeError>(global_object, String::formatted("Expected {} arguments for call, but found {}", type->parameters().size() + 1, vm.argument_count()));
size_t index = 1;
for (auto& param : type->parameters()) {
auto argument = vm.argument(index++);
double double_value = 0;
if (!argument.is_bigint())
- double_value = TRY_OR_DISCARD(argument.to_double(global_object));
+ double_value = TRY(argument.to_double(global_object));
switch (param.kind()) {
case Wasm::ValueType::Kind::I32:
arguments.append(Wasm::Value(param, static_cast<u64>(double_value)));
break;
case Wasm::ValueType::Kind::I64:
if (argument.is_bigint()) {
- auto value = TRY_OR_DISCARD(argument.to_bigint_int64(global_object));
+ auto value = TRY(argument.to_bigint_int64(global_object));
arguments.append(Wasm::Value(param, bit_cast<u64>(value)));
} else {
arguments.append(Wasm::Value(param, static_cast<u64>(double_value)));
@@ -243,10 +233,8 @@ JS_DEFINE_OLD_NATIVE_FUNCTION(WebAssemblyModule::wasm_invoke)
}
auto result = WebAssemblyModule::machine().invoke(function_address, arguments);
- if (result.is_trap()) {
- vm.throw_exception<JS::TypeError>(global_object, String::formatted("Execution trapped: {}", result.trap().reason));
- return {};
- }
+ if (result.is_trap())
+ return vm.throw_completion<JS::TypeError>(global_object, String::formatted("Execution trapped: {}", result.trap().reason));
if (result.values().is_empty())
return JS::js_null();