summaryrefslogtreecommitdiffstats
path: root/widget/nsContentProcessWidgetFactory.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /widget/nsContentProcessWidgetFactory.h
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--widget/nsContentProcessWidgetFactory.h59
1 files changed, 59 insertions, 0 deletions
diff --git a/widget/nsContentProcessWidgetFactory.h b/widget/nsContentProcessWidgetFactory.h
new file mode 100644
index 0000000000..24c09a6e48
--- /dev/null
+++ b/widget/nsContentProcessWidgetFactory.h
@@ -0,0 +1,59 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim:expandtab:shiftwidth=4:tabstop=4:
+ */
+/* 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/. */
+
+#ifndef nsContentProcessWidgetFactory_h
+#define nsContentProcessWidgetFactory_h
+
+#include "nsISupports.h"
+#include "nsComponentManagerUtils.h"
+#include "nsServiceManagerUtils.h"
+#include "nsXULAppAPI.h"
+
+#define MAKE_COMPONENT_CHOOSER(name_, parent_, content_, constructor_) \
+ static already_AddRefed<nsISupports> name_() { \
+ nsCOMPtr<nsISupports> inst; \
+ if (XRE_IsContentProcess()) { \
+ inst = constructor_(content_); \
+ } else { \
+ inst = constructor_(parent_); \
+ } \
+ return inst.forget(); \
+ }
+
+#ifdef MOZ_WIDGET_COCOA
+// This should be `do_GetService`, but test_bug466599.xhtml erroneously uses
+// `createInstance` rather than `getService`, and passes only because doing so
+// bypasses the clipboard contents cache, which does not have the expected
+// wrapping.
+MAKE_COMPONENT_CHOOSER(nsClipboardSelector,
+ "@mozilla.org/widget/parent/clipboard;1",
+ "@mozilla.org/widget/content/clipboard;1",
+ do_CreateInstance)
+#else
+MAKE_COMPONENT_CHOOSER(nsClipboardSelector,
+ "@mozilla.org/widget/parent/clipboard;1",
+ "@mozilla.org/widget/content/clipboard;1", do_GetService)
+#endif
+MAKE_COMPONENT_CHOOSER(nsColorPickerSelector,
+ "@mozilla.org/parent/colorpicker;1",
+ "@mozilla.org/content/colorpicker;1", do_CreateInstance)
+MAKE_COMPONENT_CHOOSER(nsFilePickerSelector, "@mozilla.org/parent/filepicker;1",
+ "@mozilla.org/content/filepicker;1", do_CreateInstance)
+MAKE_COMPONENT_CHOOSER(nsScreenManagerSelector,
+ "@mozilla.org/gfx/parent/screenmanager;1",
+ "@mozilla.org/gfx/content/screenmanager;1",
+ do_GetService)
+MAKE_COMPONENT_CHOOSER(nsSoundSelector, "@mozilla.org/parent/sound;1",
+ "@mozilla.org/content/sound;1", do_GetService)
+MAKE_COMPONENT_CHOOSER(nsDragServiceSelector,
+ "@mozilla.org/widget/parent/dragservice;1",
+ "@mozilla.org/widget/content/dragservice;1",
+ do_GetService)
+
+#undef MAKE_COMPONENT_CHOOSER
+
+#endif // defined nsContentProcessWidgetFactory_h