mirror of
https://github.com/RGBCube/serenity
synced 2025-05-23 18:55:08 +00:00
LibWeb: Port WebAssembly.Module to IDL
This commit is contained in:
parent
5c97ffb94f
commit
fb1f15774f
15 changed files with 121 additions and 171 deletions
44
Userland/Libraries/LibWeb/WebAssembly/Module.cpp
Normal file
44
Userland/Libraries/LibWeb/WebAssembly/Module.cpp
Normal file
|
@ -0,0 +1,44 @@
|
|||
/*
|
||||
* Copyright (c) 2021, Ali Mohammad Pur <mpfard@serenityos.org>
|
||||
* Copyright (c) 2023, Tim Flynn <trflynn89@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibJS/Runtime/Realm.h>
|
||||
#include <LibJS/Runtime/VM.h>
|
||||
#include <LibWeb/Bindings/Intrinsics.h>
|
||||
#include <LibWeb/Bindings/ModulePrototype.h>
|
||||
#include <LibWeb/WebAssembly/Module.h>
|
||||
#include <LibWeb/WebAssembly/WebAssemblyObject.h>
|
||||
|
||||
namespace Web::WebAssembly {
|
||||
|
||||
WebIDL::ExceptionOr<JS::NonnullGCPtr<Module>> Module::construct_impl(JS::Realm& realm, JS::Handle<JS::Object>& bytes)
|
||||
{
|
||||
auto& vm = realm.vm();
|
||||
|
||||
auto index = TRY(Bindings::parse_module(vm, bytes.cell()));
|
||||
return MUST_OR_THROW_OOM(vm.heap().allocate<Module>(realm, realm, index));
|
||||
}
|
||||
|
||||
Module::Module(JS::Realm& realm, size_t index)
|
||||
: Bindings::PlatformObject(realm)
|
||||
, m_index(index)
|
||||
{
|
||||
}
|
||||
|
||||
JS::ThrowCompletionOr<void> Module::initialize(JS::Realm& realm)
|
||||
{
|
||||
MUST_OR_THROW_OOM(Base::initialize(realm));
|
||||
set_prototype(&Bindings::ensure_web_prototype<Bindings::ModulePrototype>(realm, "WebAssembly.Module"sv));
|
||||
|
||||
return {};
|
||||
}
|
||||
|
||||
Wasm::Module const& Module::module() const
|
||||
{
|
||||
return Bindings::WebAssemblyObject::s_compiled_modules.at(index())->module;
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue