diff options
author | Martin Petersson <martin.petersson@nokia.com> | 2012-07-11 12:31:29 +0200 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-08-01 18:12:34 +0200 |
commit | b8453b6fe3552cdfe32c726f87bb30d897c679b0 (patch) | |
tree | 544227e592bda31eaf8ba266f33f7cadb6336a45 /src/corelib/kernel/qeventdispatcher_win.cpp | |
parent | e178b49522465becf1b0c56bff1974e6037ba9ec (diff) |
QtNetwork: Handle FD_CLOSE on Windows
We need to handle FD_CLOSE separately on Windows as this will be sent
only once. When we get FD_CLOSE we need to check if there is more data
available for reading. It there is this might indicate that there is
another FD_READ that we need to handle after the FD_CLOSE. So in this
case we will manually create another close event.
Task-number: QTBUG-19409
Task-number: QTBUG-25386
Change-Id: Ie19906bc3f64fb6a85a508a5ab12caac5d70ccdb
Reviewed-by: Shane Kearns <shane.kearns@accenture.com>
Diffstat (limited to 'src/corelib/kernel/qeventdispatcher_win.cpp')
-rw-r--r-- | src/corelib/kernel/qeventdispatcher_win.cpp | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/src/corelib/kernel/qeventdispatcher_win.cpp b/src/corelib/kernel/qeventdispatcher_win.cpp index baacfa6a80..cf182c9c29 100644 --- a/src/corelib/kernel/qeventdispatcher_win.cpp +++ b/src/corelib/kernel/qeventdispatcher_win.cpp @@ -377,7 +377,6 @@ LRESULT QT_WIN_CALLBACK qt_internal_proc(HWND hwnd, UINT message, WPARAM wp, LPA int type = -1; switch (WSAGETSELECTEVENT(lp)) { case FD_READ: - case FD_CLOSE: case FD_ACCEPT: type = 0; break; @@ -388,16 +387,24 @@ LRESULT QT_WIN_CALLBACK qt_internal_proc(HWND hwnd, UINT message, WPARAM wp, LPA case FD_OOB: type = 2; break; + case FD_CLOSE: + type = 3; + break; } if (type >= 0) { Q_ASSERT(d != 0); - QSNDict *sn_vec[3] = { &d->sn_read, &d->sn_write, &d->sn_except }; + QSNDict *sn_vec[4] = { &d->sn_read, &d->sn_write, &d->sn_except, &d->sn_read }; QSNDict *dict = sn_vec[type]; QSockNot *sn = dict ? dict->value(wp) : 0; if (sn) { - QEvent event(QEvent::SockAct); - QCoreApplication::sendEvent(sn->obj, &event); + if (type < 3) { + QEvent event(QEvent::SockAct); + QCoreApplication::sendEvent(sn->obj, &event); + } else { + QEvent event(QEvent::SockClose); + QCoreApplication::sendEvent(sn->obj, &event); + } } } return 0; |