1136386d9f
Summary: Since VirtualOutput is a QObject, store it per reference and not per value. Also fix some compilation warnings. Test Plan: Before and after 92% tests passed. Reviewers: #kwin, davidedmundson Reviewed By: davidedmundson Subscribers: kwin Tags: #kwin Differential Revision: https://phabricator.kde.org/D11581
148 lines
4 KiB
C++
148 lines
4 KiB
C++
/********************************************************************
|
|
KWin - the KDE window manager
|
|
This file is part of the KDE project.
|
|
|
|
Copyright (C) 2015 Martin Gräßlin <mgraesslin@kde.org>
|
|
|
|
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 <http://www.gnu.org/licenses/>.
|
|
*********************************************************************/
|
|
#include "virtual_backend.h"
|
|
#include "virtual_output.h"
|
|
#include "scene_qpainter_virtual_backend.h"
|
|
#include "screens_virtual.h"
|
|
#include "wayland_server.h"
|
|
#include "egl_gbm_backend.h"
|
|
// Qt
|
|
#include <QTemporaryDir>
|
|
// KWayland
|
|
#include <KWayland/Server/seat_interface.h>
|
|
// system
|
|
#include <fcntl.h>
|
|
#include <unistd.h>
|
|
#include <config-kwin.h>
|
|
#if HAVE_GBM
|
|
#include <gbm.h>
|
|
#endif
|
|
|
|
namespace KWin
|
|
{
|
|
|
|
VirtualBackend::VirtualBackend(QObject *parent)
|
|
: Platform(parent)
|
|
{
|
|
if (qEnvironmentVariableIsSet("KWIN_WAYLAND_VIRTUAL_SCREENSHOTS")) {
|
|
m_screenshotDir.reset(new QTemporaryDir);
|
|
if (!m_screenshotDir->isValid()) {
|
|
m_screenshotDir.reset();
|
|
}
|
|
if (!m_screenshotDir.isNull()) {
|
|
qDebug() << "Screenshots saved to: " << m_screenshotDir->path();
|
|
}
|
|
}
|
|
setSupportsPointerWarping(true);
|
|
setSupportsGammaControl(true);
|
|
}
|
|
|
|
VirtualBackend::~VirtualBackend()
|
|
{
|
|
#if HAVE_GBM
|
|
if (m_gbmDevice) {
|
|
gbm_device_destroy(m_gbmDevice);
|
|
}
|
|
#endif
|
|
if (m_drmFd != -1) {
|
|
close(m_drmFd);
|
|
}
|
|
}
|
|
|
|
void VirtualBackend::init()
|
|
{
|
|
/*
|
|
* Some tests currently expect one output present at start,
|
|
* others set them explicitly.
|
|
*
|
|
* TODO: rewrite all tests to explicitly set the outputs.
|
|
*/
|
|
if (!m_outputs.size()) {
|
|
VirtualOutput *dummyOutput = new VirtualOutput(this);
|
|
dummyOutput->m_geo = QRect(QPoint(0, 0), initialWindowSize());
|
|
m_outputs = { dummyOutput };
|
|
}
|
|
|
|
|
|
setSoftWareCursor(true);
|
|
setReady(true);
|
|
waylandServer()->seat()->setHasPointer(true);
|
|
waylandServer()->seat()->setHasKeyboard(true);
|
|
waylandServer()->seat()->setHasTouch(true);
|
|
|
|
emit screensQueried();
|
|
}
|
|
|
|
QString VirtualBackend::screenshotDirPath() const
|
|
{
|
|
if (m_screenshotDir.isNull()) {
|
|
return QString();
|
|
}
|
|
return m_screenshotDir->path();
|
|
}
|
|
|
|
Screens *VirtualBackend::createScreens(QObject *parent)
|
|
{
|
|
return new VirtualScreens(this, parent);
|
|
}
|
|
|
|
QPainterBackend *VirtualBackend::createQPainterBackend()
|
|
{
|
|
return new VirtualQPainterBackend(this);
|
|
}
|
|
|
|
OpenGLBackend *VirtualBackend::createOpenGLBackend()
|
|
{
|
|
return new EglGbmBackend(this);
|
|
}
|
|
|
|
void VirtualBackend::setVirtualOutputs(int count, QVector<QRect> geometries)
|
|
{
|
|
Q_ASSERT(geometries.size() == 0 || geometries.size() == count);
|
|
|
|
bool countChanged = m_outputs.size() != count;
|
|
qDeleteAll(m_outputs.begin(), m_outputs.end());
|
|
m_outputs.resize(count);
|
|
|
|
int sumWidth = 0;
|
|
for (int i = 0; i < count; i++) {
|
|
VirtualOutput *vo = new VirtualOutput(this);
|
|
if (geometries.size()) {
|
|
vo->m_geo = geometries.at(i);
|
|
} else if (!vo->m_geo.isValid()) {
|
|
vo->m_geo = QRect(QPoint(sumWidth, 0), initialWindowSize());
|
|
sumWidth += vo->m_geo.width();
|
|
}
|
|
m_outputs[i] = vo;
|
|
}
|
|
|
|
emit virtualOutputsSet(countChanged);
|
|
}
|
|
|
|
int VirtualBackend::gammaRampSize(int screen) const {
|
|
return m_outputs[screen]->m_gammaSize;
|
|
}
|
|
|
|
bool VirtualBackend::setGammaRamp(int screen, ColorCorrect::GammaRamp &gamma) {
|
|
Q_UNUSED(gamma);
|
|
return m_outputs[screen]->m_gammaResult;
|
|
}
|
|
|
|
}
|