summaryrefslogtreecommitdiffstats
path: root/src/compositor/extensions/qwaylandwindowmanagerextension.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/compositor/extensions/qwaylandwindowmanagerextension.cpp')
-rw-r--r--src/compositor/extensions/qwaylandwindowmanagerextension.cpp60
1 files changed, 30 insertions, 30 deletions
diff --git a/src/compositor/extensions/qwaylandwindowmanagerextension.cpp b/src/compositor/extensions/qwaylandwindowmanagerextension.cpp
index 160fb690f..58abd661d 100644
--- a/src/compositor/extensions/qwaylandwindowmanagerextension.cpp
+++ b/src/compositor/extensions/qwaylandwindowmanagerextension.cpp
@@ -35,64 +35,64 @@
****************************************************************************/
#include "qwaylandwindowmanagerextension.h"
+#include "qwaylandwindowmanagerextension_p.h"
-#include <wayland_wrapper/qwldisplay_p.h>
-#include <wayland_wrapper/qwlcompositor_p.h>
+#include <QtCompositor/QWaylandCompositor>
+#include <QtCompositor/QWaylandClient>
-#include <compositor_api/qwaylandclient.h>
-#include <compositor_api/qwaylandcompositor.h>
-
-#include <wayland-server.h>
-
-#include <QUrl>
+#include <QtCore/QUrl>
QT_BEGIN_NAMESPACE
-WindowManagerServerIntegration::WindowManagerServerIntegration(QWaylandCompositor *compositor, QObject *parent)
- : QWaylandExtension(compositor)
- , QtWaylandServer::qt_windowmanager()
- , m_showIsFullScreen(false)
- , m_compositor(compositor)
-{
-}
-
-WindowManagerServerIntegration::~WindowManagerServerIntegration()
+QWaylandWindowManagerExtension::QWaylandWindowManagerExtension(QWaylandCompositor *compositor, QObject *parent)
+ : QWaylandExtensionTemplate(*new QWaylandWindowManagerExtensionPrivate(compositor), parent)
{
}
-void WindowManagerServerIntegration::initialize(QtWayland::Display *waylandDisplay)
+QWaylandWindowManagerExtensionPrivate::QWaylandWindowManagerExtensionPrivate(QWaylandCompositor *compositor)
+ : QWaylandExtensionTemplatePrivateImpl(compositor)
+ , m_showIsFullScreen(false)
+ , m_compositor(compositor)
{
- init(waylandDisplay->handle(), 1);
+ init(compositor->waylandDisplay(), 1);
}
-void WindowManagerServerIntegration::setShowIsFullScreen(bool value)
+void QWaylandWindowManagerExtension::setShowIsFullScreen(bool value)
{
- m_showIsFullScreen = value;
- Q_FOREACH (Resource *resource, resourceMap().values()) {
- send_hints(resource->handle, static_cast<int32_t>(m_showIsFullScreen));
+ Q_D(QWaylandWindowManagerExtension);
+ d->m_showIsFullScreen = value;
+ Q_FOREACH (QWaylandWindowManagerExtensionPrivate::Resource *resource, d->resourceMap().values()) {
+ d->send_hints(resource->handle, static_cast<int32_t>(d->m_showIsFullScreen));
}
}
-void WindowManagerServerIntegration::sendQuitMessage(wl_client *client)
+void QWaylandWindowManagerExtension::sendQuitMessage(wl_client *client)
{
- Resource *resource = resourceMap().value(client);
+ Q_D(QWaylandWindowManagerExtension);
+ QWaylandWindowManagerExtensionPrivate::Resource *resource = d->resourceMap().value(client);
if (resource)
- send_quit(resource->handle);
+ d->send_quit(resource->handle);
+}
+
+QWaylandWindowManagerExtension *QWaylandWindowManagerExtension::get(QWaylandExtensionContainer *container)
+{
+ return static_cast<QWaylandWindowManagerExtension *>(container->extension(QtWaylandServer::qt_windowmanager::interface()));
}
-void WindowManagerServerIntegration::windowmanager_bind_resource(Resource *resource)
+void QWaylandWindowManagerExtensionPrivate::windowmanager_bind_resource(Resource *resource)
{
send_hints(resource->handle, static_cast<int32_t>(m_showIsFullScreen));
}
-void WindowManagerServerIntegration::windowmanager_destroy_resource(Resource *resource)
+void QWaylandWindowManagerExtensionPrivate::windowmanager_destroy_resource(Resource *resource)
{
m_urls.remove(resource);
}
-void WindowManagerServerIntegration::windowmanager_open_url(Resource *resource, uint32_t remaining, const QString &newUrl)
+void QWaylandWindowManagerExtensionPrivate::windowmanager_open_url(Resource *resource, uint32_t remaining, const QString &newUrl)
{
+ Q_Q(QWaylandWindowManagerExtension);
QString url = m_urls.value(resource, QString());
url.append(newUrl);
@@ -101,7 +101,7 @@ void WindowManagerServerIntegration::windowmanager_open_url(Resource *resource,
m_urls.insert(resource, url);
else {
m_urls.remove(resource);
- m_compositor->openUrl(QWaylandClient::fromWlClient(resource->client()), QUrl(url));
+ q->openUrl(QWaylandClient::fromWlClient(resource->client()), QUrl(url));
}
}