iOS: fix crash when application quits

An application will sometimes crash if the keyboard
is told to hide while the application is about to
quit. This patch will ensure that we set m_qioswindow
(and [UIView qwindow]) to 0 when the window is destroyed.
We also check this pointer before telling QUIView to
resign first responder when closing the keyboard. The
latter will fix the crash.

Task-number: QTBUG-35356

Change-Id: I934088beb7e877c5b33d96225cb215a8ffd4dbb2
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@digia.com>
This commit is contained in:
Richard Moe Gustavsen 2013-12-03 13:55:20 +01:00 committed by The Qt Project
parent dd97932a04
commit 32f71db1bd

View File

@ -341,6 +341,7 @@
// Resigning first responed status means that the virtual keyboard was closed, or // Resigning first responed status means that the virtual keyboard was closed, or
// some other view became first responder. In either case we clear the focus object to // some other view became first responder. In either case we clear the focus object to
// avoid blinking cursors in line edits etc: // avoid blinking cursors in line edits etc:
if (m_qioswindow)
static_cast<QWindowPrivate *>(QObjectPrivate::get(m_qioswindow->window()))->clearFocusObject(); static_cast<QWindowPrivate *>(QObjectPrivate::get(m_qioswindow->window()))->clearFocusObject();
return [super resignFirstResponder]; return [super resignFirstResponder];
} }
@ -423,8 +424,10 @@
- (QWindow *)qwindow - (QWindow *)qwindow
{ {
if ([self isKindOfClass:[QUIView class]]) if ([self isKindOfClass:[QUIView class]]) {
return static_cast<QUIView *>(self)->m_qioswindow->window(); if (QIOSWindow *w = static_cast<QUIView *>(self)->m_qioswindow)
return w->window();
}
return nil; return nil;
} }
@ -461,6 +464,7 @@ QIOSWindow::~QIOSWindow()
// cancellation of all touch events. // cancellation of all touch events.
[m_view touchesCancelled:0 withEvent:0]; [m_view touchesCancelled:0 withEvent:0];
m_view->m_qioswindow = 0;
[m_view removeFromSuperview]; [m_view removeFromSuperview];
[m_view release]; [m_view release];
} }