diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /widget/InProcessCompositorWidget.h | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'widget/InProcessCompositorWidget.h')
-rw-r--r-- | widget/InProcessCompositorWidget.h | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/widget/InProcessCompositorWidget.h b/widget/InProcessCompositorWidget.h new file mode 100644 index 0000000000..eb44668de9 --- /dev/null +++ b/widget/InProcessCompositorWidget.h @@ -0,0 +1,55 @@ +/* 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 mozilla_widget_InProcessCompositorWidget_h__ +#define mozilla_widget_InProcessCompositorWidget_h__ + +#include "CompositorWidget.h" + +namespace mozilla { +namespace widget { + +// This version of CompositorWidget implements a wrapper around +// nsBaseWidget. +class InProcessCompositorWidget : public CompositorWidget { + public: + explicit InProcessCompositorWidget(const layers::CompositorOptions& aOptions, + nsBaseWidget* aWidget); + + virtual bool PreRender(WidgetRenderingContext* aManager) override; + virtual void PostRender(WidgetRenderingContext* aManager) override; + virtual RefPtr<layers::NativeLayerRoot> GetNativeLayerRoot() override; + virtual already_AddRefed<gfx::DrawTarget> StartRemoteDrawing() override; + virtual already_AddRefed<gfx::DrawTarget> StartRemoteDrawingInRegion( + const LayoutDeviceIntRegion& aInvalidRegion, + layers::BufferMode* aBufferMode) override; + virtual void EndRemoteDrawing() override; + virtual void EndRemoteDrawingInRegion( + gfx::DrawTarget* aDrawTarget, + const LayoutDeviceIntRegion& aInvalidRegion) override; + virtual void CleanupRemoteDrawing() override; + virtual void CleanupWindowEffects() override; + virtual bool InitCompositor(layers::Compositor* aCompositor) override; + virtual LayoutDeviceIntSize GetClientSize() override; + virtual uint32_t GetGLFrameBufferFormat() override; + virtual void ObserveVsync(VsyncObserver* aObserver) override; + virtual uintptr_t GetWidgetKey() override; + + // If you can override this method, inherit from CompositorWidget instead. + nsIWidget* RealWidget() override; + + protected: + nsBaseWidget* mWidget; + // Bug 1679368: Maintain an additional widget pointer, constant, and + // function for sanity checking while we chase a crash. + static const char* CANARY_VALUE; + const char* mCanary; + nsBaseWidget* mWidgetSanity; + void CheckWidgetSanity(); +}; + +} // namespace widget +} // namespace mozilla + +#endif |