summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrederik Gladhorn <frederik.gladhorn@digia.com>2013-03-18 20:22:52 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2013-03-23 11:43:39 +0100
commit6d9541ae96441d849e87d763a636b8f36b416764 (patch)
treed9e0a250c8dc3d7a4fe54f8e4e18f3f15324db9b
parent6ec9b34cbb5fa6b1214cc6551002f46f732ba72f (diff)
Do not update accessibility for invalid interfaces
Change-Id: I8dc29ea51393406e529c76f25bf2f8cf426e26cf Reviewed-by: Jan Arve Sæther <jan-arve.saether@digia.com>
-rw-r--r--src/plugins/platforms/windows/accessible/qwindowsaccessibility.cpp4
-rw-r--r--src/widgets/accessible/qaccessiblewidget.cpp3
-rw-r--r--tests/auto/other/qaccessibility/tst_qaccessibility.cpp18
3 files changed, 24 insertions, 1 deletions
diff --git a/src/plugins/platforms/windows/accessible/qwindowsaccessibility.cpp b/src/plugins/platforms/windows/accessible/qwindowsaccessibility.cpp
index 752b9e7c20..146b114389 100644
--- a/src/plugins/platforms/windows/accessible/qwindowsaccessibility.cpp
+++ b/src/plugins/platforms/windows/accessible/qwindowsaccessibility.cpp
@@ -169,7 +169,9 @@ void QWindowsAccessibility::notifyAccessibilityUpdate(QAccessibleEvent *event)
// An event has to be associated with a window,
// so find the first parent that is a widget and that has a WId
QAccessibleInterface *iface = event->accessibleInterface();
- QWindow *window = iface ? QWindowsAccessibility::windowHelper(iface) : 0;
+ if (!iface) // ### This should not happen, maybe make it an assert.
+ return;
+ QWindow *window = QWindowsAccessibility::windowHelper(iface);
delete iface;
if (!window) {
diff --git a/src/widgets/accessible/qaccessiblewidget.cpp b/src/widgets/accessible/qaccessiblewidget.cpp
index 5c8d3e3a57..2b8e1a7036 100644
--- a/src/widgets/accessible/qaccessiblewidget.cpp
+++ b/src/widgets/accessible/qaccessiblewidget.cpp
@@ -205,6 +205,7 @@ QAccessibleWidget::QAccessibleWidget(QWidget *w, QAccessible::Role role, const Q
/*! \reimp */
QWindow *QAccessibleWidget::window() const
{
+ Q_ASSERT(widget());
return widget()->windowHandle();
}
@@ -343,6 +344,7 @@ QAccessibleWidget::relations(QAccessible::Relation match /*= QAccessible::AllRel
/*! \reimp */
QAccessibleInterface *QAccessibleWidget::parent() const
{
+ Q_ASSERT(widget());
QObject *parentWidget= widget()->parentWidget();
if (!parentWidget)
parentWidget = qApp;
@@ -352,6 +354,7 @@ QAccessibleInterface *QAccessibleWidget::parent() const
/*! \reimp */
QAccessibleInterface *QAccessibleWidget::child(int index) const
{
+ Q_ASSERT(widget());
QWidgetList childList = childWidgets(widget());
if (index >= 0 && index < childList.size())
return QAccessible::queryAccessibleInterface(childList.at(index));
diff --git a/tests/auto/other/qaccessibility/tst_qaccessibility.cpp b/tests/auto/other/qaccessibility/tst_qaccessibility.cpp
index f5f336ed64..ce8032e0c3 100644
--- a/tests/auto/other/qaccessibility/tst_qaccessibility.cpp
+++ b/tests/auto/other/qaccessibility/tst_qaccessibility.cpp
@@ -364,6 +364,24 @@ void tst_QAccessibility::eventTest()
QVERIFY(QTestAccessibility::containsEvent(&hideEvent));
delete button;
+
+ // Make sure that invalid events don't bring down the system
+ // these events can be in user code.
+ QWidget *widget = new QWidget();
+ QAccessibleEvent ev1(widget, QAccessible::Focus);
+ QAccessible::updateAccessibility(&ev1);
+
+ QAccessibleEvent ev2(widget, QAccessible::Focus);
+ ev2.setChild(7);
+ QAccessible::updateAccessibility(&ev2);
+ delete widget;
+
+ QObject *object = new QObject();
+ QAccessibleEvent ev3(widget, QAccessible::Focus);
+ QAccessible::updateAccessibility(&ev3);
+ delete object;
+
+ QTestAccessibility::clearEvents();
}