summaryrefslogtreecommitdiffstats
path: root/toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm')
-rw-r--r--toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm116
1 files changed, 116 insertions, 0 deletions
diff --git a/toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm b/toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm
new file mode 100644
index 0000000000..b8754b8e04
--- /dev/null
+++ b/toolkit/components/extensions/ExtensionChildDevToolsUtils.jsm
@@ -0,0 +1,116 @@
+/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
+/* vim: set sts=2 sw=2 et 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 http://mozilla.org/MPL/2.0/. */
+"use strict";
+
+/**
+ * @fileOverview
+ * This module contains utilities for interacting with DevTools
+ * from the child process.
+ */
+
+var EXPORTED_SYMBOLS = ["ExtensionChildDevToolsUtils"];
+
+const { EventEmitter } = ChromeUtils.import(
+ "resource://gre/modules/EventEmitter.jsm"
+);
+const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
+
+// Create a variable to hold the cached ThemeChangeObserver which does not
+// get created until a devtools context has been created.
+let themeChangeObserver;
+
+/**
+ * An observer that watches for changes to the devtools theme and provides
+ * that information to the devtools.panels.themeName API property, as well as
+ * emits events for the devtools.panels.onThemeChanged event. It also caches
+ * the current value of devtools.themeName.
+ */
+class ThemeChangeObserver extends EventEmitter {
+ constructor(themeName, onDestroyed) {
+ super();
+ this.themeName = themeName;
+ this.onDestroyed = onDestroyed;
+ this.contexts = new Set();
+
+ Services.cpmm.addMessageListener("Extension:DevToolsThemeChanged", this);
+ }
+
+ addContext(context) {
+ if (this.contexts.has(context)) {
+ throw new Error(
+ "addContext on the ThemeChangeObserver was called more than once" +
+ " for the context."
+ );
+ }
+
+ context.callOnClose({
+ close: () => this.onContextClosed(context),
+ });
+
+ this.contexts.add(context);
+ }
+
+ onContextClosed(context) {
+ this.contexts.delete(context);
+
+ if (this.contexts.size === 0) {
+ this.destroy();
+ }
+ }
+
+ onThemeChanged(themeName) {
+ // Update the cached themeName and emit an event for the API.
+ this.themeName = themeName;
+ this.emit("themeChanged", themeName);
+ }
+
+ receiveMessage({ name, data }) {
+ if (name === "Extension:DevToolsThemeChanged") {
+ this.onThemeChanged(data.themeName);
+ }
+ }
+
+ destroy() {
+ Services.cpmm.removeMessageListener("Extension:DevToolsThemeChanged", this);
+ this.onDestroyed();
+ this.onDestroyed = null;
+ this.contexts.clear();
+ this.contexts = null;
+ }
+}
+
+var ExtensionChildDevToolsUtils = {
+ /**
+ * Creates an cached instance of the ThemeChangeObserver class and
+ * initializes it with the current themeName. This cached instance is
+ * destroyed when all of the contexts added to it are closed.
+ *
+ * @param {string} themeName The name of the current devtools theme.
+ * @param {DevToolsContextChild} context The newly created devtools page context.
+ */
+ initThemeChangeObserver(themeName, context) {
+ if (!themeChangeObserver) {
+ themeChangeObserver = new ThemeChangeObserver(themeName, function() {
+ themeChangeObserver = null;
+ });
+ }
+ themeChangeObserver.addContext(context);
+ },
+
+ /**
+ * Returns the cached instance of ThemeChangeObserver.
+ *
+ * @returns {ThemeChangeObserver} The cached instance of ThemeChangeObserver.
+ */
+ getThemeChangeObserver() {
+ if (!themeChangeObserver) {
+ throw new Error(
+ "A ThemeChangeObserver must be created before being retrieved."
+ );
+ }
+ return themeChangeObserver;
+ },
+};