Enable shadow protocol support for all Wayland clients

The main motivation for this change is to enable support for our
proprietary shadow protocol in LayerShellV1Client.

Previously we couldn't move code that handles shadows in WaylandClient
because WaylandClient::bufferGeometry() was a pure virtual method.
This commit is contained in:
Vlad Zahorodnii 2020-09-25 09:57:28 +03:00
parent 989e0987d7
commit f24f2bd509
4 changed files with 3 additions and 8 deletions

View file

@ -32,7 +32,6 @@ InputPanelV1Client::InputPanelV1Client(InputPanelSurfaceV1Interface *panelSurfac
setSkipTaskbar(true); setSkipTaskbar(true);
setPositionSyncMode(SyncMode::Sync); setPositionSyncMode(SyncMode::Sync);
setSizeSyncMode(SyncMode::Sync); setSizeSyncMode(SyncMode::Sync);
setupCompositing();
connect(surface(), &SurfaceInterface::aboutToBeDestroyed, this, &InputPanelV1Client::destroyClient); connect(surface(), &SurfaceInterface::aboutToBeDestroyed, this, &InputPanelV1Client::destroyClient);
connect(surface(), &SurfaceInterface::sizeChanged, this, &InputPanelV1Client::reposition); connect(surface(), &SurfaceInterface::sizeChanged, this, &InputPanelV1Client::reposition);

View file

@ -50,7 +50,6 @@ LayerShellV1Client::LayerShellV1Client(LayerSurfaceV1Interface *shellSurface,
setSkipTaskbar(true); setSkipTaskbar(true);
setSizeSyncMode(SyncMode::Async); setSizeSyncMode(SyncMode::Async);
setPositionSyncMode(SyncMode::Sync); setPositionSyncMode(SyncMode::Sync);
setupCompositing();
connect(shellSurface, &LayerSurfaceV1Interface::aboutToBeDestroyed, connect(shellSurface, &LayerSurfaceV1Interface::aboutToBeDestroyed,
this, &LayerShellV1Client::destroyClient); this, &LayerShellV1Client::destroyClient);

View file

@ -41,13 +41,13 @@ Q_DECLARE_FLAGS(WaylandGeometryTypes, WaylandGeometryType)
WaylandClient::WaylandClient(SurfaceInterface *surface) WaylandClient::WaylandClient(SurfaceInterface *surface)
{ {
// Note that we cannot setup compositing here because we may need to call visibleRect(),
// which in its turn will call bufferGeometry(), which is a pure virtual method.
setSurface(surface); setSurface(surface);
setupCompositing();
m_windowId = waylandServer()->createWindowId(surface); m_windowId = waylandServer()->createWindowId(surface);
connect(surface, &SurfaceInterface::shadowChanged,
this, &WaylandClient::updateShadow);
connect(this, &WaylandClient::frameGeometryChanged, connect(this, &WaylandClient::frameGeometryChanged,
this, &WaylandClient::updateClientOutputs); this, &WaylandClient::updateClientOutputs);
connect(this, &WaylandClient::desktopFileNameChanged, connect(this, &WaylandClient::desktopFileNameChanged,

View file

@ -41,7 +41,6 @@ XdgSurfaceClient::XdgSurfaceClient(XdgSurfaceInterface *shellSurface)
{ {
setSizeSyncMode(SyncMode::Async); setSizeSyncMode(SyncMode::Async);
setPositionSyncMode(SyncMode::Async); setPositionSyncMode(SyncMode::Async);
setupCompositing();
connect(shellSurface, &XdgSurfaceInterface::configureAcknowledged, connect(shellSurface, &XdgSurfaceInterface::configureAcknowledged,
this, &XdgSurfaceClient::handleConfigureAcknowledged); this, &XdgSurfaceClient::handleConfigureAcknowledged);
@ -49,8 +48,6 @@ XdgSurfaceClient::XdgSurfaceClient(XdgSurfaceInterface *shellSurface)
this, &XdgSurfaceClient::destroyClient); this, &XdgSurfaceClient::destroyClient);
connect(shellSurface->surface(), &SurfaceInterface::committed, connect(shellSurface->surface(), &SurfaceInterface::committed,
this, &XdgSurfaceClient::handleCommit); this, &XdgSurfaceClient::handleCommit);
connect(shellSurface->surface(), &SurfaceInterface::shadowChanged,
this, &XdgSurfaceClient::updateShadow);
#if 0 // TODO: Refactor kwin core in order to uncomment this code. #if 0 // TODO: Refactor kwin core in order to uncomment this code.
connect(shellSurface->surface(), &SurfaceInterface::mapped, connect(shellSurface->surface(), &SurfaceInterface::mapped,
this, &XdgSurfaceClient::setReadyForPainting); this, &XdgSurfaceClient::setReadyForPainting);