From 76a3a31f428f665caf68f7e3b135dbfc0527e692 Mon Sep 17 00:00:00 2001 From: Vlad Zahorodnii Date: Mon, 18 Apr 2022 11:10:29 +0300 Subject: [PATCH] Remove AbstractClient plumbing casts in EffectsHandlerImpl --- src/effects.cpp | 82 +++++++++++++++++++------------------------------ 1 file changed, 31 insertions(+), 51 deletions(-) diff --git a/src/effects.cpp b/src/effects.cpp index e906a0d296..673fc59271 100644 --- a/src/effects.cpp +++ b/src/effects.cpp @@ -522,10 +522,9 @@ void EffectsHandlerImpl::slotOpacityChanged(AbstractClient *t, qreal oldOpacity) void EffectsHandlerImpl::slotClientShown(KWin::AbstractClient *t) { Q_ASSERT(t->isClient()); - auto c = static_cast(t->isClient() ? t : nullptr); - disconnect(c, &AbstractClient::windowShown, this, &EffectsHandlerImpl::slotClientShown); - setupClientConnections(c); - Q_EMIT windowAdded(c->effectWindow()); + disconnect(t, &AbstractClient::windowShown, this, &EffectsHandlerImpl::slotClientShown); + setupClientConnections(t); + Q_EMIT windowAdded(t->effectWindow()); } void EffectsHandlerImpl::slotUnmanagedShown(KWin::AbstractClient *t) @@ -910,9 +909,9 @@ QByteArray EffectsHandlerImpl::readRootProperty(long atom, long type, int format void EffectsHandlerImpl::activateWindow(EffectWindow *c) { - auto t = static_cast(c)->window(); - if (auto cl = static_cast(t->isClient() ? t : nullptr)) { - Workspace::self()->activateClient(cl, true); + auto window = static_cast(c)->window(); + if (window->isClient()) { + Workspace::self()->activateClient(window, true); } } @@ -923,33 +922,30 @@ EffectWindow *EffectsHandlerImpl::activeWindow() const void EffectsHandlerImpl::moveWindow(EffectWindow *w, const QPoint &pos, bool snap, double snapAdjust) { - auto t = static_cast(w)->window(); - auto cl = static_cast(t->isClient() ? t : nullptr); - if (!cl || !cl->isMovable()) { + auto window = static_cast(w)->window(); + if (!window->isClient() || !window->isMovable()) { return; } if (snap) { - cl->move(Workspace::self()->adjustClientPosition(cl, pos, true, snapAdjust)); + window->move(Workspace::self()->adjustClientPosition(window, pos, true, snapAdjust)); } else { - cl->move(pos); + window->move(pos); } } void EffectsHandlerImpl::windowToDesktop(EffectWindow *w, int desktop) { - auto t = static_cast(w)->window(); - auto cl = static_cast(t->isClient() ? t : nullptr); - if (cl && !cl->isDesktop() && !cl->isDock()) { - Workspace::self()->sendClientToDesktop(cl, desktop, true); + auto window = static_cast(w)->window(); + if (window->isClient() && !window->isDesktop() && !window->isDock()) { + Workspace::self()->sendClientToDesktop(window, desktop, true); } } void EffectsHandlerImpl::windowToDesktops(EffectWindow *w, const QVector &desktopIds) { - auto t = static_cast(w)->window(); - auto cl = static_cast(t->isClient() ? t : nullptr); - if (!cl || cl->isDesktop() || cl->isDock()) { + auto window = static_cast(w)->window(); + if (!window->isClient() || window->isDesktop() || window->isDock()) { return; } QVector desktops; @@ -965,16 +961,15 @@ void EffectsHandlerImpl::windowToDesktops(EffectWindow *w, const QVector & } desktops << d; } - cl->setDesktops(desktops); + window->setDesktops(desktops); } void EffectsHandlerImpl::windowToScreen(EffectWindow *w, EffectScreen *screen) { - auto t = static_cast(w)->window(); - auto cl = static_cast(t->isClient() ? t : nullptr); - if (cl && !cl->isDesktop() && !cl->isDock()) { + auto window = static_cast(w)->window(); + if (window->isClient() && !window->isDesktop() && !window->isDock()) { EffectScreenImpl *screenImpl = static_cast(screen); - Workspace::self()->sendClientToOutput(cl, screenImpl->platformOutput()); + Workspace::self()->sendClientToOutput(window, screenImpl->platformOutput()); } } @@ -1166,9 +1161,9 @@ void EffectsHandlerImpl::setElevatedWindow(KWin::EffectWindow *w, bool set) void EffectsHandlerImpl::setTabBoxWindow(EffectWindow *w) { #if KWIN_BUILD_TABBOX - auto t = static_cast(w)->window(); - if (auto c = static_cast(t->isClient() ? t : nullptr)) { - TabBox::TabBox::self()->setCurrentClient(c); + auto window = static_cast(w)->window(); + if (window->isClient()) { + TabBox::TabBox::self()->setCurrentClient(window); } #else Q_UNUSED(w) @@ -2152,12 +2147,7 @@ QRect EffectWindowImpl::decorationInnerRect() const KDecoration2::Decoration *EffectWindowImpl::decoration() const { - auto client = static_cast(toplevel->isClient() ? toplevel : nullptr); - if (!client) { - return nullptr; - } - - return client->decoration(); + return toplevel->decoration(); } QByteArray EffectWindowImpl::readProperty(long atom, long type, int format) const @@ -2177,12 +2167,7 @@ void EffectWindowImpl::deleteProperty(long int atom) const EffectWindow *EffectWindowImpl::findModal() { - auto client = static_cast(toplevel->isClient() ? toplevel : nullptr); - if (!client) { - return nullptr; - } - - AbstractClient *modal = client->findModal(); + AbstractClient *modal = toplevel->findModal(); if (modal) { return modal->effectWindow(); } @@ -2192,12 +2177,7 @@ EffectWindow *EffectWindowImpl::findModal() EffectWindow *EffectWindowImpl::transientFor() { - auto client = static_cast(toplevel->isClient() ? toplevel : nullptr); - if (!client) { - return nullptr; - } - - AbstractClient *transientFor = client->transientFor(); + AbstractClient *transientFor = toplevel->transientFor(); if (transientFor) { return transientFor->effectWindow(); } @@ -2276,22 +2256,22 @@ void EffectWindowImpl::elevate(bool elevate) void EffectWindowImpl::minimize() { - if (auto client = static_cast(toplevel->isClient() ? toplevel : nullptr)) { - client->minimize(); + if (toplevel->isClient()) { + toplevel->minimize(); } } void EffectWindowImpl::unminimize() { - if (auto client = static_cast(toplevel->isClient() ? toplevel : nullptr)) { - client->unminimize(); + if (toplevel->isClient()) { + toplevel->unminimize(); } } void EffectWindowImpl::closeWindow() { - if (auto client = static_cast(toplevel->isClient() ? toplevel : nullptr)) { - client->closeWindow(); + if (toplevel->isClient()) { + toplevel->closeWindow(); } }