backends/wayland: port away from most remaining manual memory management
This commit is contained in:
parent
297971006b
commit
b0c852aa76
7 changed files with 124 additions and 155 deletions
|
@ -65,16 +65,16 @@ namespace Wayland
|
||||||
using namespace KWayland::Client;
|
using namespace KWayland::Client;
|
||||||
|
|
||||||
WaylandCursor::WaylandCursor(WaylandBackend *backend)
|
WaylandCursor::WaylandCursor(WaylandBackend *backend)
|
||||||
: QObject(backend)
|
: m_backend(backend)
|
||||||
, m_backend(backend)
|
|
||||||
{
|
{
|
||||||
resetSurface();
|
resetSurface();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WaylandCursor::~WaylandCursor() = default;
|
||||||
|
|
||||||
void WaylandCursor::resetSurface()
|
void WaylandCursor::resetSurface()
|
||||||
{
|
{
|
||||||
delete m_surface;
|
m_surface.reset(backend()->compositor()->createSurface());
|
||||||
m_surface = backend()->compositor()->createSurface(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandCursor::init()
|
void WaylandCursor::init()
|
||||||
|
@ -82,11 +82,6 @@ void WaylandCursor::init()
|
||||||
installImage();
|
installImage();
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandCursor::~WaylandCursor()
|
|
||||||
{
|
|
||||||
delete m_surface;
|
|
||||||
}
|
|
||||||
|
|
||||||
void WaylandCursor::installImage()
|
void WaylandCursor::installImage()
|
||||||
{
|
{
|
||||||
const QImage image = Cursors::self()->currentCursor()->image();
|
const QImage image = Cursors::self()->currentCursor()->image();
|
||||||
|
@ -106,7 +101,7 @@ void WaylandCursor::doInstallImage(wl_buffer *image, const QSize &size, qreal sc
|
||||||
if (!pointer || !pointer->isValid()) {
|
if (!pointer || !pointer->isValid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
pointer->setCursor(m_surface, image ? Cursors::self()->currentCursor()->hotspot() : QPoint());
|
pointer->setCursor(m_surface.get(), image ? Cursors::self()->currentCursor()->hotspot() : QPoint());
|
||||||
drawSurface(image, size, scale);
|
drawSurface(image, size, scale);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -124,6 +119,8 @@ WaylandSubSurfaceCursor::WaylandSubSurfaceCursor(WaylandBackend *backend)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WaylandSubSurfaceCursor::~WaylandSubSurfaceCursor() = default;
|
||||||
|
|
||||||
void WaylandSubSurfaceCursor::init()
|
void WaylandSubSurfaceCursor::init()
|
||||||
{
|
{
|
||||||
if (auto *pointer = backend()->seat()->pointerDevice()->nativePointer()) {
|
if (auto *pointer = backend()->seat()->pointerDevice()->nativePointer()) {
|
||||||
|
@ -131,15 +128,9 @@ void WaylandSubSurfaceCursor::init()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandSubSurfaceCursor::~WaylandSubSurfaceCursor()
|
|
||||||
{
|
|
||||||
delete m_subSurface;
|
|
||||||
}
|
|
||||||
|
|
||||||
void WaylandSubSurfaceCursor::changeOutput(WaylandOutput *output)
|
void WaylandSubSurfaceCursor::changeOutput(WaylandOutput *output)
|
||||||
{
|
{
|
||||||
delete m_subSurface;
|
m_subSurface.reset();
|
||||||
m_subSurface = nullptr;
|
|
||||||
m_output = output;
|
m_output = output;
|
||||||
if (!output) {
|
if (!output) {
|
||||||
return;
|
return;
|
||||||
|
@ -157,15 +148,14 @@ void WaylandSubSurfaceCursor::createSubSurface()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
resetSurface();
|
resetSurface();
|
||||||
m_subSurface = backend()->subCompositor()->createSubSurface(surface(), m_output->surface(), this);
|
m_subSurface.reset(backend()->subCompositor()->createSubSurface(surface(), m_output->surface()));
|
||||||
m_subSurface->setMode(SubSurface::Mode::Desynchronized);
|
m_subSurface->setMode(SubSurface::Mode::Desynchronized);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSubSurfaceCursor::doInstallImage(wl_buffer *image, const QSize &size, qreal scale)
|
void WaylandSubSurfaceCursor::doInstallImage(wl_buffer *image, const QSize &size, qreal scale)
|
||||||
{
|
{
|
||||||
if (!image) {
|
if (!image) {
|
||||||
delete m_subSurface;
|
m_subSurface.reset();
|
||||||
m_subSurface = nullptr;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
createSubSurface();
|
createSubSurface();
|
||||||
|
@ -201,8 +191,7 @@ void WaylandSubSurfaceCursor::move(const QPointF &globalPosition)
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Keyboard *keyboard, WaylandSeat *seat)
|
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Keyboard *keyboard, WaylandSeat *seat)
|
||||||
: InputDevice(seat)
|
: m_seat(seat)
|
||||||
, m_seat(seat)
|
|
||||||
, m_keyboard(keyboard)
|
, m_keyboard(keyboard)
|
||||||
{
|
{
|
||||||
connect(keyboard, &Keyboard::keyChanged, this, [this](quint32 key, Keyboard::KeyState nativeState, quint32 time) {
|
connect(keyboard, &Keyboard::keyChanged, this, [this](quint32 key, Keyboard::KeyState nativeState, quint32 time) {
|
||||||
|
@ -231,8 +220,7 @@ WaylandInputDevice::WaylandInputDevice(KWayland::Client::Keyboard *keyboard, Way
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Pointer *pointer, WaylandSeat *seat)
|
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Pointer *pointer, WaylandSeat *seat)
|
||||||
: InputDevice(seat)
|
: m_seat(seat)
|
||||||
, m_seat(seat)
|
|
||||||
, m_pointer(pointer)
|
, m_pointer(pointer)
|
||||||
{
|
{
|
||||||
connect(pointer, &Pointer::entered, this, [this](quint32 serial, const QPointF &relativeToSurface) {
|
connect(pointer, &Pointer::entered, this, [this](quint32 serial, const QPointF &relativeToSurface) {
|
||||||
|
@ -315,8 +303,7 @@ WaylandInputDevice::WaylandInputDevice(KWayland::Client::Pointer *pointer, Wayla
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandInputDevice::WaylandInputDevice(KWayland::Client::RelativePointer *relativePointer, WaylandSeat *seat)
|
WaylandInputDevice::WaylandInputDevice(KWayland::Client::RelativePointer *relativePointer, WaylandSeat *seat)
|
||||||
: InputDevice(seat)
|
: m_seat(seat)
|
||||||
, m_seat(seat)
|
|
||||||
, m_relativePointer(relativePointer)
|
, m_relativePointer(relativePointer)
|
||||||
{
|
{
|
||||||
connect(relativePointer, &RelativePointer::relativeMotion, this, [this](const QSizeF &delta, const QSizeF &deltaNonAccelerated, quint64 timestamp) {
|
connect(relativePointer, &RelativePointer::relativeMotion, this, [this](const QSizeF &delta, const QSizeF &deltaNonAccelerated, quint64 timestamp) {
|
||||||
|
@ -325,8 +312,7 @@ WaylandInputDevice::WaylandInputDevice(KWayland::Client::RelativePointer *relati
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Touch *touch, WaylandSeat *seat)
|
WaylandInputDevice::WaylandInputDevice(KWayland::Client::Touch *touch, WaylandSeat *seat)
|
||||||
: InputDevice(seat)
|
: m_seat(seat)
|
||||||
, m_seat(seat)
|
|
||||||
, m_touch(touch)
|
, m_touch(touch)
|
||||||
{
|
{
|
||||||
connect(touch, &Touch::sequenceCanceled, this, [this]() {
|
connect(touch, &Touch::sequenceCanceled, this, [this]() {
|
||||||
|
@ -503,17 +489,16 @@ WaylandSeat::~WaylandSeat()
|
||||||
|
|
||||||
void WaylandSeat::createPointerDevice()
|
void WaylandSeat::createPointerDevice()
|
||||||
{
|
{
|
||||||
m_pointerDevice = new WaylandInputDevice(m_seat->createPointer(), this);
|
m_pointerDevice = std::make_unique<WaylandInputDevice>(m_seat->createPointer(), this);
|
||||||
Q_EMIT deviceAdded(m_pointerDevice);
|
Q_EMIT deviceAdded(m_pointerDevice.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::destroyPointerDevice()
|
void WaylandSeat::destroyPointerDevice()
|
||||||
{
|
{
|
||||||
if (m_pointerDevice) {
|
if (m_pointerDevice) {
|
||||||
Q_EMIT deviceRemoved(m_pointerDevice);
|
Q_EMIT deviceRemoved(m_pointerDevice.get());
|
||||||
destroyRelativePointer();
|
destroyRelativePointer();
|
||||||
delete m_pointerDevice;
|
m_pointerDevice.reset();
|
||||||
m_pointerDevice = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -521,59 +506,56 @@ void WaylandSeat::createRelativePointer()
|
||||||
{
|
{
|
||||||
KWayland::Client::RelativePointerManager *manager = m_backend->relativePointerManager();
|
KWayland::Client::RelativePointerManager *manager = m_backend->relativePointerManager();
|
||||||
if (manager) {
|
if (manager) {
|
||||||
m_relativePointerDevice = new WaylandInputDevice(manager->createRelativePointer(m_pointerDevice->nativePointer()), this);
|
m_relativePointerDevice = std::make_unique<WaylandInputDevice>(manager->createRelativePointer(m_pointerDevice->nativePointer()), this);
|
||||||
Q_EMIT deviceAdded(m_relativePointerDevice);
|
Q_EMIT deviceAdded(m_relativePointerDevice.get());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::destroyRelativePointer()
|
void WaylandSeat::destroyRelativePointer()
|
||||||
{
|
{
|
||||||
if (m_relativePointerDevice) {
|
if (m_relativePointerDevice) {
|
||||||
Q_EMIT deviceRemoved(m_relativePointerDevice);
|
Q_EMIT deviceRemoved(m_relativePointerDevice.get());
|
||||||
delete m_relativePointerDevice;
|
m_relativePointerDevice.reset();
|
||||||
m_relativePointerDevice = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::createKeyboardDevice()
|
void WaylandSeat::createKeyboardDevice()
|
||||||
{
|
{
|
||||||
m_keyboardDevice = new WaylandInputDevice(m_seat->createKeyboard(), this);
|
m_keyboardDevice = std::make_unique<WaylandInputDevice>(m_seat->createKeyboard(), this);
|
||||||
Q_EMIT deviceAdded(m_keyboardDevice);
|
Q_EMIT deviceAdded(m_keyboardDevice.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::destroyKeyboardDevice()
|
void WaylandSeat::destroyKeyboardDevice()
|
||||||
{
|
{
|
||||||
if (m_keyboardDevice) {
|
if (m_keyboardDevice) {
|
||||||
Q_EMIT deviceRemoved(m_keyboardDevice);
|
Q_EMIT deviceRemoved(m_keyboardDevice.get());
|
||||||
delete m_keyboardDevice;
|
m_keyboardDevice.reset();
|
||||||
m_keyboardDevice = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::createTouchDevice()
|
void WaylandSeat::createTouchDevice()
|
||||||
{
|
{
|
||||||
m_touchDevice = new WaylandInputDevice(m_seat->createTouch(), this);
|
m_touchDevice = std::make_unique<WaylandInputDevice>(m_seat->createTouch(), this);
|
||||||
Q_EMIT deviceAdded(m_touchDevice);
|
Q_EMIT deviceAdded(m_touchDevice.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandSeat::destroyTouchDevice()
|
void WaylandSeat::destroyTouchDevice()
|
||||||
{
|
{
|
||||||
if (m_touchDevice) {
|
if (m_touchDevice) {
|
||||||
Q_EMIT deviceRemoved(m_touchDevice);
|
Q_EMIT deviceRemoved(m_touchDevice.get());
|
||||||
delete m_touchDevice;
|
m_touchDevice.reset();
|
||||||
m_touchDevice = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WaylandBackend::WaylandBackend(QObject *parent)
|
WaylandBackend::WaylandBackend(QObject *parent)
|
||||||
: Platform(parent)
|
: Platform(parent)
|
||||||
, m_display(nullptr)
|
, m_display(nullptr)
|
||||||
, m_eventQueue(new EventQueue(this))
|
, m_eventQueue(std::make_unique<EventQueue>())
|
||||||
, m_registry(new Registry(this))
|
, m_registry(std::make_unique<Registry>())
|
||||||
, m_compositor(new KWayland::Client::Compositor(this))
|
, m_compositor(std::make_unique<KWayland::Client::Compositor>())
|
||||||
, m_subCompositor(new KWayland::Client::SubCompositor(this))
|
, m_subCompositor(std::make_unique<KWayland::Client::SubCompositor>())
|
||||||
, m_shm(new ShmPool(this))
|
, m_shm(std::make_unique<ShmPool>())
|
||||||
, m_connectionThreadObject(new ConnectionThread(nullptr))
|
, m_connectionThreadObject(std::make_unique<ConnectionThread>(nullptr))
|
||||||
, m_connectionThread(nullptr)
|
, m_connectionThread(nullptr)
|
||||||
{
|
{
|
||||||
connect(this, &WaylandBackend::connectionFailed, qApp, &QCoreApplication::quit);
|
connect(this, &WaylandBackend::connectionFailed, qApp, &QCoreApplication::quit);
|
||||||
|
@ -602,7 +584,7 @@ WaylandBackend::~WaylandBackend()
|
||||||
if (m_pointerConstraints) {
|
if (m_pointerConstraints) {
|
||||||
m_pointerConstraints->release();
|
m_pointerConstraints->release();
|
||||||
}
|
}
|
||||||
delete m_waylandCursor;
|
m_waylandCursor.reset();
|
||||||
|
|
||||||
m_eventQueue->release();
|
m_eventQueue->release();
|
||||||
destroyOutputs();
|
destroyOutputs();
|
||||||
|
@ -613,12 +595,11 @@ WaylandBackend::~WaylandBackend()
|
||||||
m_subCompositor->release();
|
m_subCompositor->release();
|
||||||
m_compositor->release();
|
m_compositor->release();
|
||||||
m_registry->release();
|
m_registry->release();
|
||||||
delete m_seat;
|
m_seat.reset();
|
||||||
m_shm->release();
|
m_shm->release();
|
||||||
|
|
||||||
m_connectionThread->quit();
|
m_connectionThread->quit();
|
||||||
m_connectionThread->wait();
|
m_connectionThread->wait();
|
||||||
m_connectionThreadObject->deleteLater();
|
|
||||||
#if HAVE_WAYLAND_EGL
|
#if HAVE_WAYLAND_EGL
|
||||||
gbm_device_destroy(m_gbmDevice);
|
gbm_device_destroy(m_gbmDevice);
|
||||||
#endif
|
#endif
|
||||||
|
@ -627,19 +608,19 @@ WaylandBackend::~WaylandBackend()
|
||||||
|
|
||||||
bool WaylandBackend::initialize()
|
bool WaylandBackend::initialize()
|
||||||
{
|
{
|
||||||
connect(m_registry, &Registry::compositorAnnounced, this, [this](quint32 name, quint32 version) {
|
connect(m_registry.get(), &Registry::compositorAnnounced, this, [this](quint32 name, quint32 version) {
|
||||||
if (version < 4) {
|
if (version < 4) {
|
||||||
qFatal("wl_compositor version 4 or later is required");
|
qFatal("wl_compositor version 4 or later is required");
|
||||||
}
|
}
|
||||||
m_compositor->setup(m_registry->bindCompositor(name, version));
|
m_compositor->setup(m_registry->bindCompositor(name, version));
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::subCompositorAnnounced, this, [this](quint32 name) {
|
connect(m_registry.get(), &Registry::subCompositorAnnounced, this, [this](quint32 name) {
|
||||||
m_subCompositor->setup(m_registry->bindSubCompositor(name, 1));
|
m_subCompositor->setup(m_registry->bindSubCompositor(name, 1));
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::shmAnnounced, this, [this](quint32 name) {
|
connect(m_registry.get(), &Registry::shmAnnounced, this, [this](quint32 name) {
|
||||||
m_shm->setup(m_registry->bindShm(name, 1));
|
m_shm->setup(m_registry->bindShm(name, 1));
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::relativePointerManagerUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
connect(m_registry.get(), &Registry::relativePointerManagerUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
||||||
if (m_relativePointerManager) {
|
if (m_relativePointerManager) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -648,7 +629,7 @@ bool WaylandBackend::initialize()
|
||||||
Q_EMIT pointerLockSupportedChanged();
|
Q_EMIT pointerLockSupportedChanged();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::pointerConstraintsUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
connect(m_registry.get(), &Registry::pointerConstraintsUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
||||||
if (m_pointerConstraints) {
|
if (m_pointerConstraints) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -657,23 +638,23 @@ bool WaylandBackend::initialize()
|
||||||
Q_EMIT pointerLockSupportedChanged();
|
Q_EMIT pointerLockSupportedChanged();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::pointerGesturesUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
connect(m_registry.get(), &Registry::pointerGesturesUnstableV1Announced, this, [this](quint32 name, quint32 version) {
|
||||||
if (m_pointerGestures) {
|
if (m_pointerGestures) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_pointerGestures = m_registry->createPointerGestures(name, version, this);
|
m_pointerGestures = m_registry->createPointerGestures(name, version, this);
|
||||||
});
|
});
|
||||||
connect(m_registry, &Registry::interfacesAnnounced, this, &WaylandBackend::createOutputs);
|
connect(m_registry.get(), &Registry::interfacesAnnounced, this, &WaylandBackend::createOutputs);
|
||||||
connect(m_registry, &Registry::interfacesAnnounced, this, [this]() {
|
connect(m_registry.get(), &Registry::interfacesAnnounced, this, [this]() {
|
||||||
const auto seatInterface = m_registry->interface(Registry::Interface::Seat);
|
const auto seatInterface = m_registry->interface(Registry::Interface::Seat);
|
||||||
if (seatInterface.name == 0) {
|
if (seatInterface.name == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_seat = new WaylandSeat(m_registry->createSeat(seatInterface.name, std::min(2u, seatInterface.version), this), this);
|
m_seat = std::make_unique<WaylandSeat>(m_registry->createSeat(seatInterface.name, std::min(2u, seatInterface.version), this), this);
|
||||||
Q_EMIT seatCreated();
|
Q_EMIT seatCreated();
|
||||||
|
|
||||||
m_waylandCursor = new WaylandCursor(this);
|
m_waylandCursor = std::make_unique<WaylandCursor>(this);
|
||||||
});
|
});
|
||||||
if (!deviceIdentifier().isEmpty()) {
|
if (!deviceIdentifier().isEmpty()) {
|
||||||
m_connectionThreadObject->setSocketName(deviceIdentifier());
|
m_connectionThreadObject->setSocketName(deviceIdentifier());
|
||||||
|
@ -691,14 +672,13 @@ bool WaylandBackend::initialize()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
connect(this, &WaylandBackend::pointerLockChanged, this, [this](bool locked) {
|
connect(this, &WaylandBackend::pointerLockChanged, this, [this](bool locked) {
|
||||||
delete m_waylandCursor;
|
|
||||||
if (locked) {
|
if (locked) {
|
||||||
m_waylandCursor = new WaylandSubSurfaceCursor(this);
|
m_waylandCursor = std::make_unique<WaylandSubSurfaceCursor>(this);
|
||||||
m_waylandCursor->move(input()->pointer()->pos());
|
m_waylandCursor->move(input()->pointer()->pos());
|
||||||
m_seat->createRelativePointer();
|
m_seat->createRelativePointer();
|
||||||
} else {
|
} else {
|
||||||
m_seat->destroyRelativePointer();
|
m_seat->destroyRelativePointer();
|
||||||
m_waylandCursor = new WaylandCursor(this);
|
m_waylandCursor = std::make_unique<WaylandCursor>(this);
|
||||||
}
|
}
|
||||||
m_waylandCursor->init();
|
m_waylandCursor->init();
|
||||||
});
|
});
|
||||||
|
@ -709,21 +689,21 @@ bool WaylandBackend::initialize()
|
||||||
void WaylandBackend::initConnection()
|
void WaylandBackend::initConnection()
|
||||||
{
|
{
|
||||||
connect(
|
connect(
|
||||||
m_connectionThreadObject, &ConnectionThread::connected, this, [this]() {
|
m_connectionThreadObject.get(), &ConnectionThread::connected, this, [this]() {
|
||||||
// create the event queue for the main gui thread
|
// create the event queue for the main gui thread
|
||||||
m_display = m_connectionThreadObject->display();
|
m_display = m_connectionThreadObject->display();
|
||||||
m_eventQueue->setup(m_connectionThreadObject);
|
m_eventQueue->setup(m_connectionThreadObject.get());
|
||||||
m_registry->setEventQueue(m_eventQueue);
|
m_registry->setEventQueue(m_eventQueue.get());
|
||||||
// setup registry
|
// setup registry
|
||||||
m_registry->create(m_display);
|
m_registry->create(m_display);
|
||||||
m_registry->setup();
|
m_registry->setup();
|
||||||
},
|
},
|
||||||
Qt::QueuedConnection);
|
Qt::QueuedConnection);
|
||||||
connect(
|
connect(
|
||||||
m_connectionThreadObject, &ConnectionThread::connectionDied, this, [this]() {
|
m_connectionThreadObject.get(), &ConnectionThread::connectionDied, this, [this]() {
|
||||||
setReady(false);
|
setReady(false);
|
||||||
Q_EMIT systemCompositorDied();
|
Q_EMIT systemCompositorDied();
|
||||||
delete m_seat;
|
m_seat.reset();
|
||||||
m_shm->destroy();
|
m_shm->destroy();
|
||||||
|
|
||||||
destroyOutputs();
|
destroyOutputs();
|
||||||
|
@ -740,10 +720,10 @@ void WaylandBackend::initConnection()
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
Qt::QueuedConnection);
|
Qt::QueuedConnection);
|
||||||
connect(m_connectionThreadObject, &ConnectionThread::failed, this, &WaylandBackend::connectionFailed, Qt::QueuedConnection);
|
connect(m_connectionThreadObject.get(), &ConnectionThread::failed, this, &WaylandBackend::connectionFailed, Qt::QueuedConnection);
|
||||||
|
|
||||||
m_connectionThread = new QThread(this);
|
m_connectionThread = std::make_unique<QThread>();
|
||||||
m_connectionThreadObject->moveToThread(m_connectionThread);
|
m_connectionThreadObject->moveToThread(m_connectionThread.get());
|
||||||
m_connectionThread->start();
|
m_connectionThread->start();
|
||||||
|
|
||||||
m_connectionThreadObject->initConnection();
|
m_connectionThreadObject->initConnection();
|
||||||
|
@ -765,7 +745,7 @@ void WaylandBackend::createOutputs()
|
||||||
|
|
||||||
const auto xdgIface = m_registry->interface(Registry::Interface::XdgShellStable);
|
const auto xdgIface = m_registry->interface(Registry::Interface::XdgShellStable);
|
||||||
if (xdgIface.name != 0) {
|
if (xdgIface.name != 0) {
|
||||||
m_xdgShell = m_registry->createXdgShell(xdgIface.name, xdgIface.version, this);
|
m_xdgShell.reset(m_registry->createXdgShell(xdgIface.name, xdgIface.version));
|
||||||
}
|
}
|
||||||
|
|
||||||
// we need to multiply the initial window size with the scale in order to
|
// we need to multiply the initial window size with the scale in order to
|
||||||
|
@ -781,14 +761,14 @@ void WaylandBackend::createOutputs()
|
||||||
|
|
||||||
WaylandOutput *WaylandBackend::createOutput(const QString &name, const QSize &size)
|
WaylandOutput *WaylandBackend::createOutput(const QString &name, const QSize &size)
|
||||||
{
|
{
|
||||||
auto surface = m_compositor->createSurface(this);
|
std::unique_ptr<KWayland::Client::Surface> surface{m_compositor->createSurface()};
|
||||||
if (!surface || !surface->isValid()) {
|
if (!surface || !surface->isValid()) {
|
||||||
qCCritical(KWIN_WAYLAND_BACKEND) << "Creating Wayland Surface failed";
|
qCCritical(KWIN_WAYLAND_BACKEND) << "Creating Wayland Surface failed";
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ssdManager()) {
|
if (ssdManager()) {
|
||||||
auto decoration = ssdManager()->create(surface, this);
|
auto decoration = ssdManager()->create(surface.get(), this);
|
||||||
connect(decoration, &ServerSideDecoration::modeChanged, this, [decoration] {
|
connect(decoration, &ServerSideDecoration::modeChanged, this, [decoration] {
|
||||||
if (decoration->mode() != ServerSideDecoration::Mode::Server) {
|
if (decoration->mode() != ServerSideDecoration::Mode::Server) {
|
||||||
decoration->requestMode(ServerSideDecoration::Mode::Server);
|
decoration->requestMode(ServerSideDecoration::Mode::Server);
|
||||||
|
@ -799,7 +779,7 @@ WaylandOutput *WaylandBackend::createOutput(const QString &name, const QSize &si
|
||||||
WaylandOutput *waylandOutput = nullptr;
|
WaylandOutput *waylandOutput = nullptr;
|
||||||
|
|
||||||
if (m_xdgShell && m_xdgShell->isValid()) {
|
if (m_xdgShell && m_xdgShell->isValid()) {
|
||||||
waylandOutput = new XdgShellOutput(name, surface, m_xdgShell, this, m_nextId++);
|
waylandOutput = new XdgShellOutput(name, std::move(surface), m_xdgShell.get(), this, m_nextId++);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!waylandOutput) {
|
if (!waylandOutput) {
|
||||||
|
@ -958,7 +938,7 @@ void WaylandBackend::createDpmsFilter()
|
||||||
// already another output is off
|
// already another output is off
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_dpmsFilter.reset(new DpmsInputEventFilter);
|
m_dpmsFilter = std::make_unique<DpmsInputEventFilter>();
|
||||||
input()->prependInputEventFilter(m_dpmsFilter.get());
|
input()->prependInputEventFilter(m_dpmsFilter.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -71,12 +71,11 @@ class WaylandSeat;
|
||||||
class WaylandOutput;
|
class WaylandOutput;
|
||||||
class WaylandEglBackend;
|
class WaylandEglBackend;
|
||||||
|
|
||||||
class WaylandCursor : public QObject
|
class WaylandCursor
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
|
||||||
public:
|
public:
|
||||||
explicit WaylandCursor(WaylandBackend *backend);
|
explicit WaylandCursor(WaylandBackend *backend);
|
||||||
~WaylandCursor() override;
|
virtual ~WaylandCursor();
|
||||||
|
|
||||||
virtual void init();
|
virtual void init();
|
||||||
virtual void move(const QPointF &globalPosition)
|
virtual void move(const QPointF &globalPosition)
|
||||||
|
@ -93,7 +92,7 @@ protected:
|
||||||
|
|
||||||
KWayland::Client::Surface *surface() const
|
KWayland::Client::Surface *surface() const
|
||||||
{
|
{
|
||||||
return m_surface;
|
return m_surface.get();
|
||||||
}
|
}
|
||||||
WaylandBackend *backend() const
|
WaylandBackend *backend() const
|
||||||
{
|
{
|
||||||
|
@ -101,13 +100,12 @@ protected:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
WaylandBackend *m_backend;
|
WaylandBackend *const m_backend;
|
||||||
KWayland::Client::Surface *m_surface = nullptr;
|
std::unique_ptr<KWayland::Client::Surface> m_surface;
|
||||||
};
|
};
|
||||||
|
|
||||||
class WaylandSubSurfaceCursor : public WaylandCursor
|
class WaylandSubSurfaceCursor : public WaylandCursor
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
|
||||||
public:
|
public:
|
||||||
explicit WaylandSubSurfaceCursor(WaylandBackend *backend);
|
explicit WaylandSubSurfaceCursor(WaylandBackend *backend);
|
||||||
~WaylandSubSurfaceCursor() override;
|
~WaylandSubSurfaceCursor() override;
|
||||||
|
@ -123,7 +121,7 @@ private:
|
||||||
|
|
||||||
QPointF absoluteToRelativePosition(const QPointF &position);
|
QPointF absoluteToRelativePosition(const QPointF &position);
|
||||||
WaylandOutput *m_output = nullptr;
|
WaylandOutput *m_output = nullptr;
|
||||||
KWayland::Client::SubSurface *m_subSurface = nullptr;
|
std::unique_ptr<KWayland::Client::SubSurface> m_subSurface;
|
||||||
};
|
};
|
||||||
|
|
||||||
class WaylandInputDevice : public InputDevice
|
class WaylandInputDevice : public InputDevice
|
||||||
|
@ -159,7 +157,7 @@ public:
|
||||||
KWayland::Client::Pointer *nativePointer() const;
|
KWayland::Client::Pointer *nativePointer() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
WaylandSeat *m_seat;
|
WaylandSeat *const m_seat;
|
||||||
|
|
||||||
std::unique_ptr<KWayland::Client::Keyboard> m_keyboard;
|
std::unique_ptr<KWayland::Client::Keyboard> m_keyboard;
|
||||||
std::unique_ptr<KWayland::Client::Touch> m_touch;
|
std::unique_ptr<KWayland::Client::Touch> m_touch;
|
||||||
|
@ -200,19 +198,19 @@ public:
|
||||||
|
|
||||||
WaylandInputDevice *pointerDevice() const
|
WaylandInputDevice *pointerDevice() const
|
||||||
{
|
{
|
||||||
return m_pointerDevice;
|
return m_pointerDevice.get();
|
||||||
}
|
}
|
||||||
WaylandInputDevice *relativePointerDevice() const
|
WaylandInputDevice *relativePointerDevice() const
|
||||||
{
|
{
|
||||||
return m_relativePointerDevice;
|
return m_relativePointerDevice.get();
|
||||||
}
|
}
|
||||||
WaylandInputDevice *keyboardDevice() const
|
WaylandInputDevice *keyboardDevice() const
|
||||||
{
|
{
|
||||||
return m_keyboardDevice;
|
return m_keyboardDevice.get();
|
||||||
}
|
}
|
||||||
WaylandInputDevice *touchDevice() const
|
WaylandInputDevice *touchDevice() const
|
||||||
{
|
{
|
||||||
return m_touchDevice;
|
return m_touchDevice.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
void createRelativePointer();
|
void createRelativePointer();
|
||||||
|
@ -233,10 +231,10 @@ private:
|
||||||
KWayland::Client::Seat *m_seat;
|
KWayland::Client::Seat *m_seat;
|
||||||
WaylandBackend *m_backend;
|
WaylandBackend *m_backend;
|
||||||
|
|
||||||
WaylandInputDevice *m_pointerDevice = nullptr;
|
std::unique_ptr<WaylandInputDevice> m_pointerDevice;
|
||||||
WaylandInputDevice *m_relativePointerDevice = nullptr;
|
std::unique_ptr<WaylandInputDevice> m_relativePointerDevice;
|
||||||
WaylandInputDevice *m_keyboardDevice = nullptr;
|
std::unique_ptr<WaylandInputDevice> m_keyboardDevice;
|
||||||
WaylandInputDevice *m_touchDevice = nullptr;
|
std::unique_ptr<WaylandInputDevice> m_touchDevice;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -266,7 +264,7 @@ public:
|
||||||
|
|
||||||
WaylandSeat *seat() const
|
WaylandSeat *seat() const
|
||||||
{
|
{
|
||||||
return m_seat;
|
return m_seat.get();
|
||||||
}
|
}
|
||||||
KWayland::Client::PointerGestures *pointerGestures() const
|
KWayland::Client::PointerGestures *pointerGestures() const
|
||||||
{
|
{
|
||||||
|
@ -330,25 +328,25 @@ private:
|
||||||
WaylandOutput *createOutput(const QString &name, const QSize &size);
|
WaylandOutput *createOutput(const QString &name, const QSize &size);
|
||||||
|
|
||||||
wl_display *m_display;
|
wl_display *m_display;
|
||||||
KWayland::Client::EventQueue *m_eventQueue;
|
std::unique_ptr<KWayland::Client::EventQueue> m_eventQueue;
|
||||||
KWayland::Client::Registry *m_registry;
|
std::unique_ptr<KWayland::Client::Registry> m_registry;
|
||||||
KWayland::Client::Compositor *m_compositor;
|
std::unique_ptr<KWayland::Client::Compositor> m_compositor;
|
||||||
KWayland::Client::SubCompositor *m_subCompositor;
|
std::unique_ptr<KWayland::Client::SubCompositor> m_subCompositor;
|
||||||
KWayland::Client::XdgShell *m_xdgShell = nullptr;
|
std::unique_ptr<KWayland::Client::XdgShell> m_xdgShell;
|
||||||
KWayland::Client::ShmPool *m_shm;
|
std::unique_ptr<KWayland::Client::ShmPool> m_shm;
|
||||||
KWayland::Client::ConnectionThread *m_connectionThreadObject;
|
std::unique_ptr<KWayland::Client::ConnectionThread> m_connectionThreadObject;
|
||||||
|
|
||||||
WaylandSeat *m_seat = nullptr;
|
std::unique_ptr<WaylandSeat> m_seat;
|
||||||
KWayland::Client::RelativePointerManager *m_relativePointerManager = nullptr;
|
KWayland::Client::RelativePointerManager *m_relativePointerManager = nullptr;
|
||||||
KWayland::Client::PointerConstraints *m_pointerConstraints = nullptr;
|
KWayland::Client::PointerConstraints *m_pointerConstraints = nullptr;
|
||||||
KWayland::Client::PointerGestures *m_pointerGestures = nullptr;
|
KWayland::Client::PointerGestures *m_pointerGestures = nullptr;
|
||||||
WaylandEglBackend *m_eglBackend = nullptr;
|
WaylandEglBackend *m_eglBackend = nullptr;
|
||||||
|
|
||||||
QThread *m_connectionThread;
|
std::unique_ptr<QThread> m_connectionThread;
|
||||||
QVector<WaylandOutput *> m_outputs;
|
QVector<WaylandOutput *> m_outputs;
|
||||||
int m_pendingInitialOutputs = 0;
|
int m_pendingInitialOutputs = 0;
|
||||||
|
|
||||||
WaylandCursor *m_waylandCursor = nullptr;
|
std::unique_ptr<WaylandCursor> m_waylandCursor;
|
||||||
|
|
||||||
std::unique_ptr<DpmsInputEventFilter> m_dpmsFilter;
|
std::unique_ptr<DpmsInputEventFilter> m_dpmsFilter;
|
||||||
|
|
||||||
|
@ -369,17 +367,17 @@ inline wl_display *WaylandBackend::display()
|
||||||
|
|
||||||
inline KWayland::Client::Compositor *WaylandBackend::compositor()
|
inline KWayland::Client::Compositor *WaylandBackend::compositor()
|
||||||
{
|
{
|
||||||
return m_compositor;
|
return m_compositor.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline KWayland::Client::SubCompositor *WaylandBackend::subCompositor()
|
inline KWayland::Client::SubCompositor *WaylandBackend::subCompositor()
|
||||||
{
|
{
|
||||||
return m_subCompositor;
|
return m_subCompositor.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline KWayland::Client::ShmPool *WaylandBackend::shmPool()
|
inline KWayland::Client::ShmPool *WaylandBackend::shmPool()
|
||||||
{
|
{
|
||||||
return m_shm;
|
return m_shm.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Wayland
|
} // namespace Wayland
|
||||||
|
|
|
@ -80,7 +80,7 @@ bool WaylandEglOutput::init()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
m_overlay = overlay;
|
m_overlay = overlay;
|
||||||
m_fbo.reset(new GLFramebuffer(0, nativeSize));
|
m_fbo = std::make_unique<GLFramebuffer>(0, nativeSize);
|
||||||
|
|
||||||
EGLSurface eglSurface = EGL_NO_SURFACE;
|
EGLSurface eglSurface = EGL_NO_SURFACE;
|
||||||
if (m_backend->havePlatformBase()) {
|
if (m_backend->havePlatformBase()) {
|
||||||
|
@ -114,7 +114,7 @@ GLFramebuffer *WaylandEglOutput::fbo() const
|
||||||
void WaylandEglOutput::updateSize()
|
void WaylandEglOutput::updateSize()
|
||||||
{
|
{
|
||||||
const QSize nativeSize = m_waylandOutput->geometry().size() * m_waylandOutput->scale();
|
const QSize nativeSize = m_waylandOutput->geometry().size() * m_waylandOutput->scale();
|
||||||
m_fbo.reset(new GLFramebuffer(0, nativeSize));
|
m_fbo = std::make_unique<GLFramebuffer>(0, nativeSize);
|
||||||
|
|
||||||
wl_egl_window_resize(m_overlay, nativeSize.width(), nativeSize.height(), 0, 0);
|
wl_egl_window_resize(m_overlay, nativeSize.width(), nativeSize.height(), 0, 0);
|
||||||
resetBufferAge();
|
resetBufferAge();
|
||||||
|
@ -364,7 +364,7 @@ bool WaylandEglBackend::initBufferConfigs()
|
||||||
|
|
||||||
std::shared_ptr<KWin::GLTexture> WaylandEglBackend::textureForOutput(KWin::Output *output) const
|
std::shared_ptr<KWin::GLTexture> WaylandEglBackend::textureForOutput(KWin::Output *output) const
|
||||||
{
|
{
|
||||||
std::shared_ptr<GLTexture> texture(new GLTexture(GL_RGBA8, output->pixelSize()));
|
auto texture = std::make_unique<GLTexture>(GL_RGBA8, output->pixelSize());
|
||||||
GLFramebuffer::pushFramebuffer(m_outputs[output]->fbo());
|
GLFramebuffer::pushFramebuffer(m_outputs[output]->fbo());
|
||||||
GLFramebuffer renderTarget(texture.get());
|
GLFramebuffer renderTarget(texture.get());
|
||||||
renderTarget.blitFromFramebuffer(QRect(0, texture->height(), texture->width(), -texture->height()));
|
renderTarget.blitFromFramebuffer(QRect(0, texture->height(), texture->width(), -texture->height()));
|
||||||
|
|
|
@ -24,10 +24,10 @@ namespace Wayland
|
||||||
using namespace KWayland::Client;
|
using namespace KWayland::Client;
|
||||||
static const int s_refreshRate = 60000; // TODO: can we get refresh rate data from Wayland host?
|
static const int s_refreshRate = 60000; // TODO: can we get refresh rate data from Wayland host?
|
||||||
|
|
||||||
WaylandOutput::WaylandOutput(const QString &name, Surface *surface, WaylandBackend *backend)
|
WaylandOutput::WaylandOutput(const QString &name, std::unique_ptr<Surface> &&surface, WaylandBackend *backend)
|
||||||
: Output(backend)
|
: Output(backend)
|
||||||
, m_renderLoop(std::make_unique<RenderLoop>())
|
, m_renderLoop(std::make_unique<RenderLoop>())
|
||||||
, m_surface(surface)
|
, m_surface(std::move(surface))
|
||||||
, m_backend(backend)
|
, m_backend(backend)
|
||||||
{
|
{
|
||||||
setInformation(Information{
|
setInformation(Information{
|
||||||
|
@ -36,7 +36,7 @@ WaylandOutput::WaylandOutput(const QString &name, Surface *surface, WaylandBacke
|
||||||
.capabilities = Capability::Dpms,
|
.capabilities = Capability::Dpms,
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(surface, &Surface::frameRendered, this, &WaylandOutput::frameRendered);
|
connect(m_surface.get(), &Surface::frameRendered, this, &WaylandOutput::frameRendered);
|
||||||
m_turnOffTimer.setSingleShot(true);
|
m_turnOffTimer.setSingleShot(true);
|
||||||
m_turnOffTimer.setInterval(dimAnimationTime());
|
m_turnOffTimer.setInterval(dimAnimationTime());
|
||||||
connect(&m_turnOffTimer, &QTimer::timeout, this, [this] {
|
connect(&m_turnOffTimer, &QTimer::timeout, this, [this] {
|
||||||
|
@ -47,7 +47,6 @@ WaylandOutput::WaylandOutput(const QString &name, Surface *surface, WaylandBacke
|
||||||
WaylandOutput::~WaylandOutput()
|
WaylandOutput::~WaylandOutput()
|
||||||
{
|
{
|
||||||
m_surface->destroy();
|
m_surface->destroy();
|
||||||
delete m_surface;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RenderLoop *WaylandOutput::renderLoop() const
|
RenderLoop *WaylandOutput::renderLoop() const
|
||||||
|
@ -113,15 +112,15 @@ void WaylandOutput::updateEnabled(bool enabled)
|
||||||
setState(next);
|
setState(next);
|
||||||
}
|
}
|
||||||
|
|
||||||
XdgShellOutput::XdgShellOutput(const QString &name, Surface *surface, XdgShell *xdgShell, WaylandBackend *backend, int number)
|
XdgShellOutput::XdgShellOutput(const QString &name, std::unique_ptr<Surface> &&waylandSurface, XdgShell *xdgShell, WaylandBackend *backend, int number)
|
||||||
: WaylandOutput(name, surface, backend)
|
: WaylandOutput(name, std::move(waylandSurface), backend)
|
||||||
|
, m_xdgShellSurface(xdgShell->createSurface(surface()))
|
||||||
, m_number(number)
|
, m_number(number)
|
||||||
{
|
{
|
||||||
m_xdgShellSurface = xdgShell->createSurface(surface, this);
|
|
||||||
updateWindowTitle();
|
updateWindowTitle();
|
||||||
|
|
||||||
connect(m_xdgShellSurface, &XdgShellSurface::configureRequested, this, &XdgShellOutput::handleConfigure);
|
connect(m_xdgShellSurface.get(), &XdgShellSurface::configureRequested, this, &XdgShellOutput::handleConfigure);
|
||||||
connect(m_xdgShellSurface, &XdgShellSurface::closeRequested, qApp, &QCoreApplication::quit);
|
connect(m_xdgShellSurface.get(), &XdgShellSurface::closeRequested, qApp, &QCoreApplication::quit);
|
||||||
connect(this, &WaylandOutput::enabledChanged, this, &XdgShellOutput::updateWindowTitle);
|
connect(this, &WaylandOutput::enabledChanged, this, &XdgShellOutput::updateWindowTitle);
|
||||||
connect(this, &WaylandOutput::dpmsModeChanged, this, &XdgShellOutput::updateWindowTitle);
|
connect(this, &WaylandOutput::dpmsModeChanged, this, &XdgShellOutput::updateWindowTitle);
|
||||||
|
|
||||||
|
@ -142,13 +141,12 @@ XdgShellOutput::XdgShellOutput(const QString &name, Surface *surface, XdgShell *
|
||||||
updateWindowTitle();
|
updateWindowTitle();
|
||||||
});
|
});
|
||||||
|
|
||||||
surface->commit(KWayland::Client::Surface::CommitFlag::None);
|
surface()->commit(KWayland::Client::Surface::CommitFlag::None);
|
||||||
}
|
}
|
||||||
|
|
||||||
XdgShellOutput::~XdgShellOutput()
|
XdgShellOutput::~XdgShellOutput()
|
||||||
{
|
{
|
||||||
m_xdgShellSurface->destroy();
|
m_xdgShellSurface->destroy();
|
||||||
delete m_xdgShellSurface;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void XdgShellOutput::handleConfigure(const QSize &size, XdgShellSurface::States states, quint32 serial)
|
void XdgShellOutput::handleConfigure(const QSize &size, XdgShellSurface::States states, quint32 serial)
|
||||||
|
@ -194,8 +192,7 @@ void XdgShellOutput::lockPointer(Pointer *pointer, bool lock)
|
||||||
{
|
{
|
||||||
if (!lock) {
|
if (!lock) {
|
||||||
const bool surfaceWasLocked = m_pointerLock && m_hasPointerLock;
|
const bool surfaceWasLocked = m_pointerLock && m_hasPointerLock;
|
||||||
delete m_pointerLock;
|
m_pointerLock.reset();
|
||||||
m_pointerLock = nullptr;
|
|
||||||
m_hasPointerLock = false;
|
m_hasPointerLock = false;
|
||||||
if (surfaceWasLocked) {
|
if (surfaceWasLocked) {
|
||||||
Q_EMIT backend()->pointerLockChanged(false);
|
Q_EMIT backend()->pointerLockChanged(false);
|
||||||
|
@ -204,21 +201,17 @@ void XdgShellOutput::lockPointer(Pointer *pointer, bool lock)
|
||||||
}
|
}
|
||||||
|
|
||||||
Q_ASSERT(!m_pointerLock);
|
Q_ASSERT(!m_pointerLock);
|
||||||
m_pointerLock = backend()->pointerConstraints()->lockPointer(surface(), pointer, nullptr,
|
m_pointerLock.reset(backend()->pointerConstraints()->lockPointer(surface(), pointer, nullptr, PointerConstraints::LifeTime::OneShot));
|
||||||
PointerConstraints::LifeTime::OneShot,
|
|
||||||
this);
|
|
||||||
if (!m_pointerLock->isValid()) {
|
if (!m_pointerLock->isValid()) {
|
||||||
delete m_pointerLock;
|
m_pointerLock.reset();
|
||||||
m_pointerLock = nullptr;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
connect(m_pointerLock, &LockedPointer::locked, this, [this]() {
|
connect(m_pointerLock.get(), &LockedPointer::locked, this, [this]() {
|
||||||
m_hasPointerLock = true;
|
m_hasPointerLock = true;
|
||||||
Q_EMIT backend()->pointerLockChanged(true);
|
Q_EMIT backend()->pointerLockChanged(true);
|
||||||
});
|
});
|
||||||
connect(m_pointerLock, &LockedPointer::unlocked, this, [this]() {
|
connect(m_pointerLock.get(), &LockedPointer::unlocked, this, [this]() {
|
||||||
delete m_pointerLock;
|
m_pointerLock.reset();
|
||||||
m_pointerLock = nullptr;
|
|
||||||
m_hasPointerLock = false;
|
m_hasPointerLock = false;
|
||||||
Q_EMIT backend()->pointerLockChanged(false);
|
Q_EMIT backend()->pointerLockChanged(false);
|
||||||
});
|
});
|
||||||
|
|
|
@ -39,7 +39,7 @@ class WaylandOutput : public Output
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
WaylandOutput(const QString &name, KWayland::Client::Surface *surface, WaylandBackend *backend);
|
WaylandOutput(const QString &name, std::unique_ptr<KWayland::Client::Surface> &&surface, WaylandBackend *backend);
|
||||||
~WaylandOutput() override;
|
~WaylandOutput() override;
|
||||||
|
|
||||||
RenderLoop *renderLoop() const override;
|
RenderLoop *renderLoop() const override;
|
||||||
|
@ -61,7 +61,7 @@ public:
|
||||||
|
|
||||||
KWayland::Client::Surface *surface() const
|
KWayland::Client::Surface *surface() const
|
||||||
{
|
{
|
||||||
return m_surface;
|
return m_surface.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
void setDpmsMode(DpmsMode mode) override;
|
void setDpmsMode(DpmsMode mode) override;
|
||||||
|
@ -81,7 +81,7 @@ protected:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unique_ptr<RenderLoop> m_renderLoop;
|
std::unique_ptr<RenderLoop> m_renderLoop;
|
||||||
KWayland::Client::Surface *m_surface;
|
std::unique_ptr<KWayland::Client::Surface> m_surface;
|
||||||
WaylandBackend *m_backend;
|
WaylandBackend *m_backend;
|
||||||
QTimer m_turnOffTimer;
|
QTimer m_turnOffTimer;
|
||||||
};
|
};
|
||||||
|
@ -90,7 +90,7 @@ class XdgShellOutput : public WaylandOutput
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
XdgShellOutput(const QString &name,
|
XdgShellOutput(const QString &name,
|
||||||
KWayland::Client::Surface *surface,
|
std::unique_ptr<KWayland::Client::Surface> &&surface,
|
||||||
KWayland::Client::XdgShell *xdgShell,
|
KWayland::Client::XdgShell *xdgShell,
|
||||||
WaylandBackend *backend, int number);
|
WaylandBackend *backend, int number);
|
||||||
~XdgShellOutput() override;
|
~XdgShellOutput() override;
|
||||||
|
@ -101,9 +101,9 @@ private:
|
||||||
void handleConfigure(const QSize &size, KWayland::Client::XdgShellSurface::States states, quint32 serial);
|
void handleConfigure(const QSize &size, KWayland::Client::XdgShellSurface::States states, quint32 serial);
|
||||||
void updateWindowTitle();
|
void updateWindowTitle();
|
||||||
|
|
||||||
KWayland::Client::XdgShellSurface *m_xdgShellSurface = nullptr;
|
std::unique_ptr<KWayland::Client::XdgShellSurface> m_xdgShellSurface;
|
||||||
int m_number;
|
int m_number;
|
||||||
KWayland::Client::LockedPointer *m_pointerLock = nullptr;
|
std::unique_ptr<KWayland::Client::LockedPointer> m_pointerLock;
|
||||||
bool m_hasPointerLock = false;
|
bool m_hasPointerLock = false;
|
||||||
bool m_hasBeenConfigured = false;
|
bool m_hasBeenConfigured = false;
|
||||||
};
|
};
|
||||||
|
|
|
@ -44,7 +44,6 @@ WaylandQPainterOutput::WaylandQPainterOutput(WaylandOutput *output)
|
||||||
|
|
||||||
WaylandQPainterOutput::~WaylandQPainterOutput()
|
WaylandQPainterOutput::~WaylandQPainterOutput()
|
||||||
{
|
{
|
||||||
qDeleteAll(m_slots);
|
|
||||||
m_slots.clear();
|
m_slots.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,7 +62,7 @@ void WaylandQPainterOutput::remapBuffer()
|
||||||
qCDebug(KWIN_WAYLAND_BACKEND) << "Remapped back buffer of surface" << m_waylandOutput->surface();
|
qCDebug(KWIN_WAYLAND_BACKEND) << "Remapped back buffer of surface" << m_waylandOutput->surface();
|
||||||
|
|
||||||
const QSize nativeSize(m_waylandOutput->geometry().size() * m_waylandOutput->scale());
|
const QSize nativeSize(m_waylandOutput->geometry().size() * m_waylandOutput->scale());
|
||||||
for (WaylandQPainterBufferSlot *slot : qAsConst(m_slots)) {
|
for (const auto &slot : m_slots) {
|
||||||
slot->image = QImage(slot->buffer->address(), nativeSize.width(), nativeSize.height(), QImage::Format_ARGB32);
|
slot->image = QImage(slot->buffer->address(), nativeSize.width(), nativeSize.height(), QImage::Format_ARGB32);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,14 +71,13 @@ void WaylandQPainterOutput::updateSize(const QSize &size)
|
||||||
{
|
{
|
||||||
Q_UNUSED(size)
|
Q_UNUSED(size)
|
||||||
m_back = nullptr;
|
m_back = nullptr;
|
||||||
qDeleteAll(m_slots);
|
|
||||||
m_slots.clear();
|
m_slots.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaylandQPainterOutput::present()
|
void WaylandQPainterOutput::present()
|
||||||
{
|
{
|
||||||
for (WaylandQPainterBufferSlot *slot : qAsConst(m_slots)) {
|
for (const auto &slot : m_slots) {
|
||||||
if (slot == m_back) {
|
if (slot.get() == m_back) {
|
||||||
slot->age = 1;
|
slot->age = 1;
|
||||||
} else if (slot->age > 0) {
|
} else if (slot->age > 0) {
|
||||||
slot->age++;
|
slot->age++;
|
||||||
|
@ -100,9 +98,9 @@ WaylandQPainterBufferSlot *WaylandQPainterOutput::back() const
|
||||||
|
|
||||||
WaylandQPainterBufferSlot *WaylandQPainterOutput::acquire()
|
WaylandQPainterBufferSlot *WaylandQPainterOutput::acquire()
|
||||||
{
|
{
|
||||||
for (WaylandQPainterBufferSlot *slot : qAsConst(m_slots)) {
|
for (const auto &slot : m_slots) {
|
||||||
if (slot->buffer->isReleased()) {
|
if (slot->buffer->isReleased()) {
|
||||||
m_back = slot;
|
m_back = slot.get();
|
||||||
slot->buffer->setReleased(false);
|
slot->buffer->setReleased(false);
|
||||||
return m_back;
|
return m_back;
|
||||||
}
|
}
|
||||||
|
@ -115,8 +113,8 @@ WaylandQPainterBufferSlot *WaylandQPainterOutput::acquire()
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_back = new WaylandQPainterBufferSlot(buffer);
|
m_slots.push_back(std::make_unique<WaylandQPainterBufferSlot>(buffer));
|
||||||
m_slots.append(m_back);
|
m_back = m_slots.back().get();
|
||||||
|
|
||||||
// qCDebug(KWIN_WAYLAND_BACKEND) << "Created a new back buffer for output surface" << m_waylandOutput->surface();
|
// qCDebug(KWIN_WAYLAND_BACKEND) << "Created a new back buffer for output surface" << m_waylandOutput->surface();
|
||||||
return m_back;
|
return m_back;
|
||||||
|
|
|
@ -71,7 +71,7 @@ private:
|
||||||
KWayland::Client::ShmPool *m_pool;
|
KWayland::Client::ShmPool *m_pool;
|
||||||
DamageJournal m_damageJournal;
|
DamageJournal m_damageJournal;
|
||||||
|
|
||||||
QVector<WaylandQPainterBufferSlot *> m_slots;
|
std::vector<std::unique_ptr<WaylandQPainterBufferSlot>> m_slots;
|
||||||
WaylandQPainterBufferSlot *m_back = nullptr;
|
WaylandQPainterBufferSlot *m_back = nullptr;
|
||||||
|
|
||||||
friend class WaylandQPainterBackend;
|
friend class WaylandQPainterBackend;
|
||||||
|
|
Loading…
Reference in a new issue