diff --git a/Userland/Libraries/LibWeb/HTML/WorkerGlobalScope.cpp b/Userland/Libraries/LibWeb/HTML/WorkerGlobalScope.cpp
index 98194d8ea8..de252ae32c 100644
--- a/Userland/Libraries/LibWeb/HTML/WorkerGlobalScope.cpp
+++ b/Userland/Libraries/LibWeb/HTML/WorkerGlobalScope.cpp
@@ -10,6 +10,7 @@
#include
#include
#include
+#include
#include
#include
#include
@@ -33,7 +34,9 @@ WorkerGlobalScope::~WorkerGlobalScope() = default;
JS::ThrowCompletionOr WorkerGlobalScope::initialize(JS::Realm& realm)
{
MUST_OR_THROW_OOM(Base::initialize(realm));
- m_navigator = WorkerNavigator::create(*this);
+ m_navigator = TRY(Bindings::throw_dom_exception_if_needed(realm.vm(), [&]() {
+ return WorkerNavigator::create(*this);
+ }));
return {};
}
diff --git a/Userland/Libraries/LibWeb/HTML/WorkerNavigator.cpp b/Userland/Libraries/LibWeb/HTML/WorkerNavigator.cpp
index e43ef7b7b1..d868d46930 100644
--- a/Userland/Libraries/LibWeb/HTML/WorkerNavigator.cpp
+++ b/Userland/Libraries/LibWeb/HTML/WorkerNavigator.cpp
@@ -11,9 +11,9 @@
namespace Web::HTML {
-JS::NonnullGCPtr WorkerNavigator::create(WorkerGlobalScope& global_scope)
+WebIDL::ExceptionOr> WorkerNavigator::create(WorkerGlobalScope& global_scope)
{
- return global_scope.heap().allocate(global_scope.realm(), global_scope).release_allocated_value_but_fixme_should_propagate_errors();
+ return MUST_OR_THROW_OOM(global_scope.heap().allocate(global_scope.realm(), global_scope));
}
WorkerNavigator::WorkerNavigator(WorkerGlobalScope& global_scope)
diff --git a/Userland/Libraries/LibWeb/HTML/WorkerNavigator.h b/Userland/Libraries/LibWeb/HTML/WorkerNavigator.h
index d111884375..323cd82523 100644
--- a/Userland/Libraries/LibWeb/HTML/WorkerNavigator.h
+++ b/Userland/Libraries/LibWeb/HTML/WorkerNavigator.h
@@ -22,7 +22,7 @@ class WorkerNavigator : public Bindings::PlatformObject
WEB_PLATFORM_OBJECT(WorkerNavigator, Bindings::PlatformObject);
public:
- static JS::NonnullGCPtr create(WorkerGlobalScope&);
+ static WebIDL::ExceptionOr> create(WorkerGlobalScope&);
virtual ~WorkerNavigator() override;