/******************************************************************** KWin - the KDE window manager This file is part of the KDE project. Copyright (C) 2013 Martin Gräßlin This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . *********************************************************************/ #ifndef KWIN_WAYLAND_BACKEND_H #define KWIN_WAYLAND_BACKEND_H // KWin #include // Qt #include #include #include #include #include class QTemporaryFile; struct wl_cursor_image; struct wl_cursor_theme; struct wl_buffer; struct wl_display; struct wl_event_queue; struct wl_seat; namespace KWayland { namespace Client { class Buffer; class ShmPool; class Compositor; class ConnectionThread; class EventQueue; class FullscreenShell; class Keyboard; class Output; class Pointer; class Registry; class Seat; class Shell; class ShellSurface; class SubCompositor; class SubSurface; class Surface; } } namespace KWin { namespace Wayland { class WaylandBackend; class WaylandSeat; class WaylandCursorTheme : public QObject { Q_OBJECT public: explicit WaylandCursorTheme(WaylandBackend *backend, QObject *parent = nullptr); virtual ~WaylandCursorTheme(); wl_cursor_image *get(Qt::CursorShape shape); private: void loadTheme(); void destroyTheme(); wl_cursor_theme *m_theme; WaylandBackend *m_backend; }; class WaylandSeat : public QObject { Q_OBJECT public: WaylandSeat(wl_seat *seat, WaylandBackend *backend); virtual ~WaylandSeat(); void installCursorImage(wl_buffer *image, const QSize &size, const QPoint &hotspot); void installCursorImage(Qt::CursorShape shape); void installCursorImage(const QImage &image, const QPoint &hotspot); void setInstallCursor(bool install); bool isInstallCursor() const { return m_installCursor; } private: void destroyPointer(); void destroyKeyboard(); KWayland::Client::Seat *m_seat; KWayland::Client::Pointer *m_pointer; KWayland::Client::Keyboard *m_keyboard; KWayland::Client::Surface *m_cursor; WaylandCursorTheme *m_theme; uint32_t m_enteredSerial; WaylandBackend *m_backend; bool m_installCursor; }; class WaylandCursor : public QObject { Q_OBJECT public: explicit WaylandCursor(KWayland::Client::Surface *parentSurface, WaylandBackend *backend); void setHotSpot(const QPoint &pos); const QPoint &hotSpot() const { return m_hotSpot; } void setCursorImage(wl_buffer *image, const QSize &size, const QPoint &hotspot); void setCursorImage(const QImage &image, const QPoint &hotspot); void setCursorImage(Qt::CursorShape shape); Q_SIGNALS: void hotSpotChanged(const QPoint &); private: WaylandBackend *m_backend; QPoint m_hotSpot; KWayland::Client::SubSurface *m_subSurface; WaylandCursorTheme *m_theme; }; /** * @brief Class encapsulating all Wayland data structures needed by the Egl backend. * * It creates the connection to the Wayland Compositor, sets up the registry and creates * the Wayland surface and its shell mapping. */ class KWIN_EXPORT WaylandBackend : public QObject { Q_OBJECT public: virtual ~WaylandBackend(); wl_display *display(); KWayland::Client::Compositor *compositor(); const QList &outputs() const; KWayland::Client::ShmPool *shmPool(); KWayland::Client::SubCompositor *subCompositor(); KWayland::Client::Surface *surface() const; QSize shellSurfaceSize() const; void installCursorImage(Qt::CursorShape shape); void installCursorFromServer(); protected: void connectNotify(const QMetaMethod &signal) override; Q_SIGNALS: void shellSurfaceSizeChanged(const QSize &size); void systemCompositorDied(); void backendReady(); void outputsChanged(); void connectionFailed(); private: void initConnection(); void createSurface(); void destroyOutputs(); void checkBackendReady(); wl_display *m_display; KWayland::Client::EventQueue *m_eventQueue; KWayland::Client::Registry *m_registry; KWayland::Client::Compositor *m_compositor; KWayland::Client::Shell *m_shell; KWayland::Client::Surface *m_surface; KWayland::Client::ShellSurface *m_shellSurface; QScopedPointer m_seat; KWayland::Client::ShmPool *m_shm; QList m_outputs; KWayland::Client::ConnectionThread *m_connectionThreadObject; QThread *m_connectionThread; KWayland::Client::FullscreenShell *m_fullscreenShell; KWayland::Client::SubCompositor *m_subCompositor; WaylandCursor *m_cursor; bool m_ready = false; KWIN_SINGLETON(WaylandBackend) }; inline wl_display *WaylandBackend::display() { return m_display; } inline KWayland::Client::Compositor *WaylandBackend::compositor() { return m_compositor; } inline KWayland::Client::SubCompositor *WaylandBackend::subCompositor() { return m_subCompositor; } inline KWayland::Client::ShmPool* WaylandBackend::shmPool() { return m_shm; } inline KWayland::Client::Surface *WaylandBackend::surface() const { return m_surface; } inline const QList< KWayland::Client::Output* >& WaylandBackend::outputs() const { return m_outputs; } } // namespace Wayland } // namespace KWin #endif // KWIN_WAYLAND_BACKEND_H