summaryrefslogtreecommitdiffstats
path: root/dom/worklet/WorkletImpl.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
commit43a97878ce14b72f0981164f87f2e35e14151312 (patch)
tree620249daf56c0258faa40cbdcf9cfba06de2a846 /dom/worklet/WorkletImpl.cpp
parentInitial commit. (diff)
downloadfirefox-upstream.tar.xz
firefox-upstream.zip
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/worklet/WorkletImpl.cpp')
-rw-r--r--dom/worklet/WorkletImpl.cpp142
1 files changed, 142 insertions, 0 deletions
diff --git a/dom/worklet/WorkletImpl.cpp b/dom/worklet/WorkletImpl.cpp
new file mode 100644
index 0000000000..42679880bd
--- /dev/null
+++ b/dom/worklet/WorkletImpl.cpp
@@ -0,0 +1,142 @@
+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=8 sts=2 et sw=2 tw=80: */
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
+
+#include "WorkletImpl.h"
+
+#include "Worklet.h"
+#include "WorkletThread.h"
+
+#include "mozilla/BasePrincipal.h"
+#include "mozilla/NullPrincipal.h"
+#include "mozilla/dom/DocGroup.h"
+#include "mozilla/dom/RegisterWorkletBindings.h"
+#include "mozilla/dom/ScriptSettings.h"
+#include "mozilla/dom/WorkletBinding.h"
+#include "mozilla/dom/WorkletGlobalScope.h"
+#include "nsGlobalWindowInner.h"
+
+namespace mozilla {
+
+// ---------------------------------------------------------------------------
+// WorkletLoadInfo
+
+WorkletLoadInfo::WorkletLoadInfo(nsPIDOMWindowInner* aWindow)
+ : mInnerWindowID(aWindow->WindowID()) {
+ MOZ_ASSERT(NS_IsMainThread());
+ nsPIDOMWindowOuter* outerWindow = aWindow->GetOuterWindow();
+ if (outerWindow) {
+ mOuterWindowID = outerWindow->WindowID();
+ } else {
+ mOuterWindowID = 0;
+ }
+}
+
+// ---------------------------------------------------------------------------
+// WorkletImpl
+
+WorkletImpl::WorkletImpl(nsPIDOMWindowInner* aWindow, nsIPrincipal* aPrincipal)
+ : mPrincipal(NullPrincipal::CreateWithInheritedAttributes(aPrincipal)),
+ mWorkletLoadInfo(aWindow),
+ mTerminated(false),
+ mFinishedOnExecutionThread(false),
+ mTrials(OriginTrials::FromWindow(nsGlobalWindowInner::Cast(aWindow))) {
+ Unused << NS_WARN_IF(
+ NS_FAILED(ipc::PrincipalToPrincipalInfo(mPrincipal, &mPrincipalInfo)));
+
+ if (aWindow->GetDocGroup()) {
+ mAgentClusterId.emplace(aWindow->GetDocGroup()->AgentClusterId());
+ }
+
+ mSharedMemoryAllowed =
+ nsGlobalWindowInner::Cast(aWindow)->IsSharedMemoryAllowed();
+
+ mShouldResistFingerprinting =
+ aWindow->AsGlobal()->ShouldResistFingerprinting();
+}
+
+WorkletImpl::~WorkletImpl() { MOZ_ASSERT(!mGlobalScope); }
+
+JSObject* WorkletImpl::WrapWorklet(JSContext* aCx, dom::Worklet* aWorklet,
+ JS::Handle<JSObject*> aGivenProto) {
+ MOZ_ASSERT(NS_IsMainThread());
+ return dom::Worklet_Binding::Wrap(aCx, aWorklet, aGivenProto);
+}
+
+dom::WorkletGlobalScope* WorkletImpl::GetGlobalScope() {
+ dom::WorkletThread::AssertIsOnWorkletThread();
+
+ if (mGlobalScope) {
+ return mGlobalScope;
+ }
+ if (mFinishedOnExecutionThread) {
+ return nullptr;
+ }
+
+ dom::AutoJSAPI jsapi;
+ jsapi.Init();
+ JSContext* cx = jsapi.cx();
+
+ mGlobalScope = ConstructGlobalScope();
+
+ JS::Rooted<JSObject*> global(cx);
+ NS_ENSURE_TRUE(mGlobalScope->WrapGlobalObject(cx, &global), nullptr);
+
+ JSAutoRealm ar(cx, global);
+
+ // Init Web IDL bindings
+ if (!dom::RegisterWorkletBindings(cx, global)) {
+ return nullptr;
+ }
+
+ JS_FireOnNewGlobalObject(cx, global);
+
+ return mGlobalScope;
+}
+
+void WorkletImpl::NotifyWorkletFinished() {
+ MOZ_ASSERT(NS_IsMainThread());
+
+ if (mTerminated) {
+ return;
+ }
+
+ // Release global scope on its thread.
+ SendControlMessage(
+ NS_NewRunnableFunction("WorkletImpl::NotifyWorkletFinished",
+ [self = RefPtr<WorkletImpl>(this)]() {
+ self->mFinishedOnExecutionThread = true;
+ self->mGlobalScope = nullptr;
+ }));
+
+ mTerminated = true;
+ if (mWorkletThread) {
+ mWorkletThread->Terminate();
+ mWorkletThread = nullptr;
+ }
+}
+
+nsresult WorkletImpl::SendControlMessage(
+ already_AddRefed<nsIRunnable> aRunnable) {
+ MOZ_ASSERT(NS_IsMainThread());
+ RefPtr<nsIRunnable> runnable = std::move(aRunnable);
+
+ // TODO: bug 1492011 re ConsoleWorkletRunnable.
+ if (mTerminated) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+
+ if (!mWorkletThread) {
+ // Thread creation. FIXME: this will change.
+ mWorkletThread = dom::WorkletThread::Create(this);
+ if (!mWorkletThread) {
+ return NS_ERROR_ILLEGAL_DURING_SHUTDOWN;
+ }
+ }
+
+ return mWorkletThread->DispatchRunnable(runnable.forget());
+}
+
+} // namespace mozilla