From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- widget/gtk/X11CompositorWidget.cpp | 108 +++++++++++++++++++++++++++++++++++++ 1 file changed, 108 insertions(+) create mode 100644 widget/gtk/X11CompositorWidget.cpp (limited to 'widget/gtk/X11CompositorWidget.cpp') diff --git a/widget/gtk/X11CompositorWidget.cpp b/widget/gtk/X11CompositorWidget.cpp new file mode 100644 index 000000000..05113a0c3 --- /dev/null +++ b/widget/gtk/X11CompositorWidget.cpp @@ -0,0 +1,108 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* 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/. */ + +#include "X11CompositorWidget.h" + +#include "gfxPlatformGtk.h" +#include "mozilla/layers/CompositorThread.h" +#include "mozilla/widget/InProcessCompositorWidget.h" +#include "mozilla/widget/PlatformWidgetTypes.h" +#include "nsWindow.h" + +namespace mozilla { +namespace widget { + +X11CompositorWidget::X11CompositorWidget(const CompositorWidgetInitData& aInitData, + nsWindow* aWindow) + : mWidget(aWindow) +{ + // If we have a nsWindow, then grab the already existing display connection + // If we don't, then use the init data to connect to the display + if (aWindow) { + mXDisplay = aWindow->XDisplay(); + } else { + mXDisplay = XOpenDisplay(aInitData.XDisplayString().get()); + } + mXWindow = (Window)aInitData.XWindow(); + + // Grab the window's visual and depth + XWindowAttributes windowAttrs; + XGetWindowAttributes(mXDisplay, mXWindow, &windowAttrs); + + Visual* visual = windowAttrs.visual; + int depth = windowAttrs.depth; + + // Initialize the window surface provider + mProvider.Initialize( + mXDisplay, + mXWindow, + visual, + depth + ); + + mClientSize = aInitData.InitialClientSize(); +} + +X11CompositorWidget::~X11CompositorWidget() +{ + mProvider.CleanupResources(); + + // If we created our own display connection, we need to destroy it + if (!mWidget && mXDisplay) { + XCloseDisplay(mXDisplay); + mXDisplay = nullptr; + } +} + +already_AddRefed +X11CompositorWidget::StartRemoteDrawing() +{ + return nullptr; +} +void +X11CompositorWidget::EndRemoteDrawing() +{ +} + +already_AddRefed +X11CompositorWidget::StartRemoteDrawingInRegion(LayoutDeviceIntRegion& aInvalidRegion, + layers::BufferMode* aBufferMode) +{ + return mProvider.StartRemoteDrawingInRegion(aInvalidRegion, + aBufferMode); +} + +void X11CompositorWidget::EndRemoteDrawingInRegion(gfx::DrawTarget* aDrawTarget, + LayoutDeviceIntRegion& aInvalidRegion) +{ + mProvider.EndRemoteDrawingInRegion(aDrawTarget, + aInvalidRegion); +} + +nsIWidget* X11CompositorWidget::RealWidget() +{ + return mWidget; +} + +void +X11CompositorWidget::NotifyClientSizeChanged(const LayoutDeviceIntSize& aClientSize) +{ + mClientSize = aClientSize; +} + +LayoutDeviceIntSize +X11CompositorWidget::GetClientSize() +{ + return mClientSize; +} + +uintptr_t +X11CompositorWidget::GetWidgetKey() +{ + return reinterpret_cast(mWidget); +} + +} // namespace widget +} // namespace mozilla -- cgit v1.2.3