diff options
author | Sami Merila <sami.merila@nokia.com> | 2011-05-30 10:22:06 (GMT) |
---|---|---|
committer | Sami Merila <sami.merila@nokia.com> | 2011-05-30 10:22:06 (GMT) |
commit | a9c76a7403b573ebe69d324d0b2f16f367c3a458 (patch) | |
tree | 904fb5c683ab60b0940df86b656ec197f54fe455 /src/gui | |
parent | f32377e2038369cbf2822875cd8836b1f70feb6e (diff) | |
download | Qt-a9c76a7403b573ebe69d324d0b2f16f367c3a458.zip Qt-a9c76a7403b573ebe69d324d0b2f16f367c3a458.tar.gz Qt-a9c76a7403b573ebe69d324d0b2f16f367c3a458.tar.bz2 |
Fix QMenuBar autotest failures for Symbian
Effectively three fixes to reach same autotest results as on other
Symbian devices and to make the case not crash (itself, or Qt).
a) Fix null pointer usage in QWidget.
This is mostly theoretic case, since it requires that previous focus
widget has widget, yet it doesn't have internal winId. Still test case
manages to make this happen, so lets prevent the null pointer use.
b) Skip activatedCount_noQt3() test case,
since it would require shortcut support and leads to test crash.
Qt for Symbian should have shortcut support as a result of task
http://bugreports.qt.nokia.com/browse/QTBUG-5730
c) Ensure that menu has at least 360 width in tests that send keypresses
to the menu. Otherwise, menuitems might get set into menu extension,
which makes highlight tests fail (since item is not visible).
Task-number: QT-5053
Reviewed-by: Tomi Vihria
Diffstat (limited to 'src/gui')
-rw-r--r-- | src/gui/kernel/qapplication_s60.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/gui/kernel/qapplication_s60.cpp b/src/gui/kernel/qapplication_s60.cpp index b3f9eec..96ac6f4 100644 --- a/src/gui/kernel/qapplication_s60.cpp +++ b/src/gui/kernel/qapplication_s60.cpp @@ -2005,7 +2005,7 @@ void QApplicationPrivate::openPopup(QWidget *popup) QApplicationPrivate::popupWidgets->append(popup); // Cancel focus widget pointer capture and long tap timer - if (QApplication::focusWidget()) { + if (QApplication::focusWidget() && QApplication::focusWidget()->effectiveWinId()) { static_cast<QSymbianControl*>(QApplication::focusWidget()->effectiveWinId())->CancelLongTapTimer(); QApplication::focusWidget()->effectiveWinId()->SetPointerCapture(false); } |