summaryrefslogtreecommitdiffstats
path: root/src/widgets/widgets/qwidgetanimator_p.h
diff options
context:
space:
mode:
authorRohan McGovern <rohan.mcgovern@nokia.com>2012-10-22 14:19:24 +1000
committerThe Qt Project <gerrit-noreply@qt-project.org>2012-10-25 12:18:15 +0200
commit33214af3784feacb2d5188bbf07da92f45f582f9 (patch)
tree8057817307511c2481a79c755d180153ed5c6460 /src/widgets/widgets/qwidgetanimator_p.h
parent82cb34b05f59b3e3f2d641304381ea9d359bc67b (diff)
Fixed crash on destruction of animating QDockWidget in a QMainWindow
It doesn't make sense to hold an unguarded pointer to a QPropertyAnimation while assigning ownership of that animation to the animated widget. Destruction of the widget while the animation is in progress causes the animation pointer to become dangling; then the widget is removed from the containing QMainWindowLayout, which attempts to abort the animation, dereferencing the invalid pointer. The crash can be reproduced sometimes with tst_QDockWidget::taskQTBUG_2940_resizeAfterUndocking (which is in Qt4 only). Change-Id: I758bf7193b2ea39cd4d8e87197d8ff957d3368eb Reviewed-by: Robin Burchell <robin+qt@viroteck.net> Reviewed-by: Andy Shaw <andy.shaw@digia.com>
Diffstat (limited to 'src/widgets/widgets/qwidgetanimator_p.h')
-rw-r--r--src/widgets/widgets/qwidgetanimator_p.h3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/widgets/widgets/qwidgetanimator_p.h b/src/widgets/widgets/qwidgetanimator_p.h
index 5649488c13..98963ce0bc 100644
--- a/src/widgets/widgets/qwidgetanimator_p.h
+++ b/src/widgets/widgets/qwidgetanimator_p.h
@@ -55,6 +55,7 @@
#include <qobject.h>
#include <qhash.h>
+#include <qpointer.h>
QT_BEGIN_NAMESPACE
@@ -79,7 +80,7 @@ private Q_SLOTS:
#endif
private:
- typedef QHash<QWidget*, QPropertyAnimation*> AnimationMap;
+ typedef QHash<QWidget*, QPointer<QPropertyAnimation> > AnimationMap;
AnimationMap m_animation_map;
QMainWindowLayout *m_mainWindowLayout;
};