Review Request 120160: KMessageWidget: fix handling of rapid succession of animatedHide+animatedShow calls

Dominik Haumann dhaumann at kde.org
Sun Sep 14 18:33:27 UTC 2014


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/120160/#review66489
-----------------------------------------------------------


All in all, the patch looks good, but it misses emitting the signals hideAnimationFinished() and showAnimationFinished().
Why? Without your patch, you can be *sure* that after calling show() or animatedShow() the signal showAnimationFinished() will eventually be emitted.
With the current version of your patch, this is not true anymore. For instance, KatePart relies on these signals to work.

I'd be fine with committing this to KF5, but I would suggest to not backport to 4.x.


src/kmessagewidget.cpp
<https://git.reviewboard.kde.org/r/120160/#comment46355>

    I believe this is missing after line 411:
    emit showAnimationFinished();



src/kmessagewidget.cpp
<https://git.reviewboard.kde.org/r/120160/#comment46354>

    I believe this is missing after line 441:
    emit hideAnimationFinished();


- Dominik Haumann


On Sept. 12, 2014, 12:16 p.m., Fabio D'Urso wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/120160/
> -----------------------------------------------------------
> 
> (Updated Sept. 12, 2014, 12:16 p.m.)
> 
> 
> Review request for KDE Frameworks, Christoph Feck and Aurélien Gâteau.
> 
> 
> Repository: kwidgetsaddons
> 
> 
> Description
> -------
> 
> Hi, I've found that if you call animatedShow() immediatly after animatedHide(), without waiting for the hide animation to finish first, the hide animation goes on and, in the end, the message widget becomes hidden.
> 
> The attached patch adds checks in animatedShow and animatedHide so that, if an opposite animation is currently running, they just reverse it.
> 
> 
> Diffs
> -----
> 
>   autotests/kmessagewidgetautotest.h 062e2b3 
>   autotests/kmessagewidgetautotest.cpp f46bab0 
>   src/kmessagewidget.cpp bc7ba32 
>   tests/kmessagewidgettest.cpp f621b5a 
> 
> Diff: https://git.reviewboard.kde.org/r/120160/diff/
> 
> 
> Testing
> -------
> 
> I've added buttons to invoke animatedShow and animatedHide in tests/kmessagewidget.cpp and used them to test the behavior.
> 
> I've also added an autotest that checks the final height and isVisible() value, both after single animatedShow/animatedHide calls and after animatedShow+animatedHide and animatedHide+animatedShow.
> 
> 
> Thanks,
> 
> Fabio D'Urso
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20140914/7c29d1a1/attachment.html>


More information about the Kde-frameworks-devel mailing list