DecoratedClientImpl switches from operating on Client to AbstractClient
parent
4873b2933f
commit
6270ea35a2
|
@ -20,7 +20,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#include "decoratedclient.h"
|
#include "decoratedclient.h"
|
||||||
#include "decorationpalette.h"
|
#include "decorationpalette.h"
|
||||||
#include "decorationrenderer.h"
|
#include "decorationrenderer.h"
|
||||||
#include "client.h"
|
#include "abstract_client.h"
|
||||||
#include "composite.h"
|
#include "composite.h"
|
||||||
#include "cursor.h"
|
#include "cursor.h"
|
||||||
#include "options.h"
|
#include "options.h"
|
||||||
|
@ -37,7 +37,7 @@ namespace KWin
|
||||||
namespace Decoration
|
namespace Decoration
|
||||||
{
|
{
|
||||||
|
|
||||||
DecoratedClientImpl::DecoratedClientImpl(Client *client, KDecoration2::DecoratedClient *decoratedClient, KDecoration2::Decoration *decoration)
|
DecoratedClientImpl::DecoratedClientImpl(AbstractClient *client, KDecoration2::DecoratedClient *decoratedClient, KDecoration2::Decoration *decoration)
|
||||||
: QObject()
|
: QObject()
|
||||||
, DecoratedClientPrivate(decoratedClient, decoration)
|
, DecoratedClientPrivate(decoratedClient, decoration)
|
||||||
, m_client(client)
|
, m_client(client)
|
||||||
|
@ -45,40 +45,40 @@ DecoratedClientImpl::DecoratedClientImpl(Client *client, KDecoration2::Decorated
|
||||||
{
|
{
|
||||||
createRenderer();
|
createRenderer();
|
||||||
client->setDecoratedClient(QPointer<DecoratedClientImpl>(this));
|
client->setDecoratedClient(QPointer<DecoratedClientImpl>(this));
|
||||||
connect(client, &Client::activeChanged, this,
|
connect(client, &AbstractClient::activeChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
emit decoratedClient->activeChanged(client->isActive());
|
emit decoratedClient->activeChanged(client->isActive());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::geometryChanged, this,
|
connect(client, &AbstractClient::geometryChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
emit decoratedClient->widthChanged(client->clientSize().width());
|
emit decoratedClient->widthChanged(client->clientSize().width());
|
||||||
emit decoratedClient->heightChanged(client->clientSize().height());
|
emit decoratedClient->heightChanged(client->clientSize().height());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::desktopChanged, this,
|
connect(client, &AbstractClient::desktopChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
emit decoratedClient->onAllDesktopsChanged(client->isOnAllDesktops());
|
emit decoratedClient->onAllDesktopsChanged(client->isOnAllDesktops());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::captionChanged, this,
|
connect(client, &AbstractClient::captionChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
emit decoratedClient->captionChanged(client->caption());
|
emit decoratedClient->captionChanged(client->caption());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::iconChanged, this,
|
connect(client, &AbstractClient::iconChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
emit decoratedClient->iconChanged(client->icon());
|
emit decoratedClient->iconChanged(client->icon());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::shadeChanged, this,
|
connect(client, &AbstractClient::shadeChanged, this,
|
||||||
[decoratedClient, client]() {
|
[decoratedClient, client]() {
|
||||||
// TODO: geometry is wrong
|
// TODO: geometry is wrong
|
||||||
emit decoratedClient->shadedChanged(client->isShade());
|
emit decoratedClient->shadedChanged(client->isShade());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::keepAboveChanged, decoratedClient, &KDecoration2::DecoratedClient::keepAboveChanged);
|
connect(client, &AbstractClient::keepAboveChanged, decoratedClient, &KDecoration2::DecoratedClient::keepAboveChanged);
|
||||||
connect(client, &Client::keepBelowChanged, decoratedClient, &KDecoration2::DecoratedClient::keepBelowChanged);
|
connect(client, &AbstractClient::keepBelowChanged, decoratedClient, &KDecoration2::DecoratedClient::keepBelowChanged);
|
||||||
connect(Compositor::self(), &Compositor::compositingToggled, this,
|
connect(Compositor::self(), &Compositor::compositingToggled, this,
|
||||||
[this, decoration]() {
|
[this, decoration]() {
|
||||||
delete m_renderer;
|
delete m_renderer;
|
||||||
|
@ -87,17 +87,17 @@ DecoratedClientImpl::DecoratedClientImpl(Client *client, KDecoration2::Decorated
|
||||||
decoration->update();
|
decoration->update();
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::quickTileModeChanged, decoratedClient,
|
connect(client, &AbstractClient::quickTileModeChanged, decoratedClient,
|
||||||
[this, decoratedClient]() {
|
[this, decoratedClient]() {
|
||||||
emit decoratedClient->adjacentScreenEdgesChanged(adjacentScreenEdges());
|
emit decoratedClient->adjacentScreenEdgesChanged(adjacentScreenEdges());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
connect(client, &Client::closeableChanged, decoratedClient, &KDecoration2::DecoratedClient::closeableChanged);
|
connect(client, &AbstractClient::closeableChanged, decoratedClient, &KDecoration2::DecoratedClient::closeableChanged);
|
||||||
connect(client, &Client::shadeableChanged, decoratedClient, &KDecoration2::DecoratedClient::shadeableChanged);
|
connect(client, &AbstractClient::shadeableChanged, decoratedClient, &KDecoration2::DecoratedClient::shadeableChanged);
|
||||||
connect(client, &Client::minimizeableChanged, decoratedClient, &KDecoration2::DecoratedClient::minimizeableChanged);
|
connect(client, &AbstractClient::minimizeableChanged, decoratedClient, &KDecoration2::DecoratedClient::minimizeableChanged);
|
||||||
connect(client, &Client::maximizeableChanged, decoratedClient, &KDecoration2::DecoratedClient::maximizeableChanged);
|
connect(client, &AbstractClient::maximizeableChanged, decoratedClient, &KDecoration2::DecoratedClient::maximizeableChanged);
|
||||||
|
|
||||||
connect(client, &Client::paletteChanged, decoratedClient, &KDecoration2::DecoratedClient::paletteChanged);
|
connect(client, &AbstractClient::paletteChanged, decoratedClient, &KDecoration2::DecoratedClient::paletteChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
DecoratedClientImpl::~DecoratedClientImpl() = default;
|
DecoratedClientImpl::~DecoratedClientImpl() = default;
|
||||||
|
@ -220,25 +220,25 @@ bool DecoratedClientImpl::isMaximizedHorizontally() const
|
||||||
Qt::Edges DecoratedClientImpl::adjacentScreenEdges() const
|
Qt::Edges DecoratedClientImpl::adjacentScreenEdges() const
|
||||||
{
|
{
|
||||||
Qt::Edges edges;
|
Qt::Edges edges;
|
||||||
const Client::QuickTileMode mode = m_client->quickTileMode();
|
const AbstractClient::QuickTileMode mode = m_client->quickTileMode();
|
||||||
if (mode.testFlag(Client::QuickTileLeft)) {
|
if (mode.testFlag(AbstractClient::QuickTileLeft)) {
|
||||||
edges |= Qt::LeftEdge;
|
edges |= Qt::LeftEdge;
|
||||||
if (!mode.testFlag(Client::QuickTileTop) && !mode.testFlag(Client::QuickTileBottom)) {
|
if (!mode.testFlag(AbstractClient::QuickTileTop) && !mode.testFlag(AbstractClient::QuickTileBottom)) {
|
||||||
// using complete side
|
// using complete side
|
||||||
edges |= Qt::TopEdge | Qt::BottomEdge;
|
edges |= Qt::TopEdge | Qt::BottomEdge;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mode.testFlag(Client::QuickTileTop)) {
|
if (mode.testFlag(AbstractClient::QuickTileTop)) {
|
||||||
edges |= Qt::TopEdge;
|
edges |= Qt::TopEdge;
|
||||||
}
|
}
|
||||||
if (mode.testFlag(Client::QuickTileRight)) {
|
if (mode.testFlag(AbstractClient::QuickTileRight)) {
|
||||||
edges |= Qt::RightEdge;
|
edges |= Qt::RightEdge;
|
||||||
if (!mode.testFlag(Client::QuickTileTop) && !mode.testFlag(Client::QuickTileBottom)) {
|
if (!mode.testFlag(AbstractClient::QuickTileTop) && !mode.testFlag(AbstractClient::QuickTileBottom)) {
|
||||||
// using complete side
|
// using complete side
|
||||||
edges |= Qt::TopEdge | Qt::BottomEdge;
|
edges |= Qt::TopEdge | Qt::BottomEdge;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mode.testFlag(Client::QuickTileBottom)) {
|
if (mode.testFlag(AbstractClient::QuickTileBottom)) {
|
||||||
edges |= Qt::BottomEdge;
|
edges |= Qt::BottomEdge;
|
||||||
}
|
}
|
||||||
return edges;
|
return edges;
|
||||||
|
|
|
@ -27,7 +27,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
namespace KWin
|
namespace KWin
|
||||||
{
|
{
|
||||||
|
|
||||||
class Client;
|
|
||||||
class AbstractClient;
|
class AbstractClient;
|
||||||
|
|
||||||
namespace Decoration
|
namespace Decoration
|
||||||
|
@ -39,7 +38,7 @@ class DecoratedClientImpl : public QObject, public KDecoration2::DecoratedClient
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit DecoratedClientImpl(Client *client, KDecoration2::DecoratedClient *decoratedClient, KDecoration2::Decoration *decoration);
|
explicit DecoratedClientImpl(AbstractClient *client, KDecoration2::DecoratedClient *decoratedClient, KDecoration2::Decoration *decoration);
|
||||||
virtual ~DecoratedClientImpl();
|
virtual ~DecoratedClientImpl();
|
||||||
QString caption() const override;
|
QString caption() const override;
|
||||||
WId decorationId() const override;
|
WId decorationId() const override;
|
||||||
|
|
Loading…
Reference in New Issue