From abecbf2369f524b1c11454f446d9b7dc9d25ad8b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Gr=C3=A4=C3=9Flin?= Date: Mon, 17 Mar 2014 10:22:20 +0100 Subject: [PATCH] [kwin] Port away from deprecated functionality in KWindowSystem Less warnings and more type safety. --- composite.cpp | 2 +- events.cpp | 41 ++++++++++++++++++++------------------ geometry.cpp | 2 +- kcmkwin/kwinrules/main.cpp | 2 +- 4 files changed, 25 insertions(+), 22 deletions(-) diff --git a/composite.cpp b/composite.cpp index 0a83fb28de..8e961b6554 100644 --- a/composite.cpp +++ b/composite.cpp @@ -317,7 +317,7 @@ void Compositor::finish() ++it) { // forward all opacity values to the frame in case there'll be other CM running if ((*it)->opacity() != 1.0) { - NETWinInfo i(connection(), (*it)->frameId(), rootWindow(), 0); + NETWinInfo i(connection(), (*it)->frameId(), rootWindow(), 0, 0); i.setOpacity(static_cast< unsigned long >((*it)->opacity() * 0xffffffff)); } } diff --git a/events.cpp b/events.cpp index a2ba41f245..463462dc15 100644 --- a/events.cpp +++ b/events.cpp @@ -152,11 +152,12 @@ bool Workspace::workspaceEvent(xcb_generic_event_t *e) } if (eventType == XCB_PROPERTY_NOTIFY || eventType == XCB_CLIENT_MESSAGE) { - unsigned long dirty[ NETRootInfo::PROPERTIES_SIZE ]; - rootInfo()->event(e, dirty, NETRootInfo::PROPERTIES_SIZE); - if (dirty[ NETRootInfo::PROTOCOLS ] & NET::DesktopNames) + NET::Properties dirtyProtocols; + NET::Properties2 dirtyProtocols2; + rootInfo()->event(e, &dirtyProtocols, &dirtyProtocols2); + if (dirtyProtocols & NET::DesktopNames) VirtualDesktopManager::self()->save(); - if (dirty[ NETRootInfo::PROTOCOLS2 ] & NET::WM2DesktopLayout) + if (dirtyProtocols2 & NET::WM2DesktopLayout) VirtualDesktopManager::self()->updateLayout(); } @@ -482,40 +483,41 @@ bool Workspace::workspaceEvent(QEvent* e) bool Client::windowEvent(xcb_generic_event_t *e) { if (findEventWindow(e) == window()) { // avoid doing stuff on frame or wrapper - unsigned long dirty[ 2 ]; + NET::Properties dirtyProperties; + NET::Properties2 dirtyProperties2; double old_opacity = opacity(); - info->event(e, dirty, 2); // pass through the NET stuff + info->event(e, &dirtyProperties, &dirtyProperties2); // pass through the NET stuff - if ((dirty[ NETWinInfo::PROTOCOLS ] & NET::WMName) != 0) + if ((dirtyProperties & NET::WMName) != 0) fetchName(); - if ((dirty[ NETWinInfo::PROTOCOLS ] & NET::WMIconName) != 0) + if ((dirtyProperties & NET::WMIconName) != 0) fetchIconicName(); - if ((dirty[ NETWinInfo::PROTOCOLS ] & NET::WMStrut) != 0 - || (dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2ExtendedStrut) != 0) { + if ((dirtyProperties & NET::WMStrut) != 0 + || (dirtyProperties2 & NET::WM2ExtendedStrut) != 0) { workspace()->updateClientArea(); } - if ((dirty[ NETWinInfo::PROTOCOLS ] & NET::WMIcon) != 0) + if ((dirtyProperties & NET::WMIcon) != 0) getIcons(); // Note there's a difference between userTime() and info->userTime() // info->userTime() is the value of the property, userTime() also includes // updates of the time done by KWin (ButtonPress on windowrapper etc.). - if ((dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2UserTime) != 0) { + if ((dirtyProperties2 & NET::WM2UserTime) != 0) { workspace()->setWasUserInteraction(); updateUserTime(info->userTime()); } - if ((dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2StartupId) != 0) + if ((dirtyProperties2 & NET::WM2StartupId) != 0) startupIdChanged(); - if (dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2Opacity) { + if (dirtyProperties2 & NET::WM2Opacity) { if (compositing()) { addRepaintFull(); emit opacityChanged(this, old_opacity); } else { // forward to the frame if there's possibly another compositing manager running - NETWinInfo i(connection(), frameId(), rootWindow(), 0); + NETWinInfo i(connection(), frameId(), rootWindow(), 0, 0); i.setOpacity(info->opacity()); } } - if (dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2FrameOverlap) { + if (dirtyProperties2 & NET::WM2FrameOverlap) { // ### Inform the decoration } } @@ -1494,9 +1496,10 @@ void Client::syncEvent(xcb_sync_alarm_notify_event_t* e) bool Unmanaged::windowEvent(xcb_generic_event_t *e) { double old_opacity = opacity(); - unsigned long dirty[ 2 ]; - info->event(e, dirty, 2); // pass through the NET stuff - if (dirty[ NETWinInfo::PROTOCOLS2 ] & NET::WM2Opacity) { + NET::Properties dirtyProperties; + NET::Properties2 dirtyProperties2; + info->event(e, &dirtyProperties, &dirtyProperties2); // pass through the NET stuff + if (dirtyProperties2 & NET::WM2Opacity) { if (compositing()) { addRepaintFull(); emit opacityChanged(this, old_opacity); diff --git a/geometry.cpp b/geometry.cpp index c3e212282e..c63342723f 100644 --- a/geometry.cpp +++ b/geometry.cpp @@ -816,7 +816,7 @@ void Workspace::setClientIsMoving(Client *c) // (the property with the size of the frame remains on the window after the crash). void Workspace::fixPositionAfterCrash(xcb_window_t w, const xcb_get_geometry_reply_t *geometry) { - NETWinInfo i(connection(), w, rootWindow(), NET::WMFrameExtents); + NETWinInfo i(connection(), w, rootWindow(), NET::WMFrameExtents, 0); NETStrut frame = i.frameExtents(); if (frame.left != 0 || frame.top != 0) { diff --git a/kcmkwin/kwinrules/main.cpp b/kcmkwin/kwinrules/main.cpp index 3386aa4f2d..915bd2fa2b 100644 --- a/kcmkwin/kwinrules/main.cpp +++ b/kcmkwin/kwinrules/main.cpp @@ -68,7 +68,7 @@ static void saveRules(const QList< Rules* >& rules) static Rules* findRule(const QList< Rules* >& rules, Window wid, bool whole_app) { - KWindowInfo info = KWindowSystem::windowInfo(wid, + KWindowInfo info = KWindowInfo(wid, NET::WMName | NET::WMWindowType, NET::WM2WindowClass | NET::WM2WindowRole | NET::WM2ClientMachine); if (!info.valid()) // shouldn't really happen