Review Request 129146: Fix emitting close when an event has no actions
David Edmundson
david at davidedmundson.co.uk
Tue Oct 11 13:26:19 UTC 2016
> On Oct. 11, 2016, 12:16 p.m., Anthony Fieroni wrote:
> > src/knotificationmanager.cpp, line 203
> > <https://git.reviewboard.kde.org/r/129146/diff/1/?file=481937#file481937line203>
> >
> > n->close()
>
> David Edmundson wrote:
> I did think about that, but what if the userspace code is:
>
> KNotification *n = new KNoti..
> n->ref();
> n->sendEvent();
>
> we wouldn't want to close immediately.
>
> Anthony Fieroni wrote:
> User must *never* do that, ref/deref interface is only for manager.
It's documented as being available for user use:
https://api.kde.org/frameworks-api/frameworks-apidocs/frameworks/knotifications/html/classKNotification.html#ac37dbd2cccd26af667bea20a7df831c3
>void KNotification::ref ( )
>The notification will automatically be closed if all presentations are finished.
>if you want to show your own presentation in your application, you should use this function, so it will not be automatically closed when there is nothing to show.
>Don't forgot to deref, or the notification may be never closed if there is no timeout.
- David
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/129146/#review99930
-----------------------------------------------------------
On Oct. 11, 2016, 11:19 a.m., David Edmundson wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/129146/
> -----------------------------------------------------------
>
> (Updated Oct. 11, 2016, 11:19 a.m.)
>
>
> Review request for KDE Frameworks.
>
>
> Repository: knotifications
>
>
> Description
> -------
>
> KNotificatitionManager::self() has an early check if a notification has
> no actions. If it has no actions it tries to close the notification
> early. However it's dereferencing an object that it has not referenced,
> sending the ref count to -1, a corrupt state that is not handled
> gracefully in KNotification, and we don't ever close the notification.
>
> By referencing and dereferencing we're still calling the cleanup in
> KNotification (if applicable) but without sending the ref count negative.
>
> This fixes ksmserver waiting for the logout sound to play; which
> currently never emits close, as the default setup has no logout sound.
>
>
> Diffs
> -----
>
> autotests/knotification_test.cpp 5d063f1a19d7f5e4d8c77d7e6301e81223401b08
> src/knotificationmanager.cpp c315db9a3f17771d4095cfdc7982475949213a1c
>
> Diff: https://git.reviewboard.kde.org/r/129146/diff/
>
>
> Testing
> -------
>
> Autotest that used to fail included
>
>
> Thanks,
>
> David Edmundson
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20161011/591d9b65/attachment.html>
More information about the Kde-frameworks-devel
mailing list