+ if ( len == 0 && work->workData.ioData.len != 0 ) {
+ /* Given the following scenario:
+ * - a console handler has been registered that handles Ctrl+C
+ * events.
+ * - we've not tweaked the 'console mode' settings to turn on
+ * ENABLE_PROCESSED_INPUT.
+ * - we're blocked waiting on input from standard input.
+ * - the user hits Ctrl+C.
+ *
+ * The OS will invoke the console handler (in a separate OS thread),
+ * and the above read() (i.e., under the hood, a ReadFile() op) returns
+ * 0, with the error set to ERROR_OPERATION_ABORTED. We don't
+ * want to percolate this non-EOF condition too far back up, but ignore
+ * it. However, we do want to give the RTS an opportunity to deliver the
+ * console event.
+ *
+ * Hence, we set 'errorCode' to (-2), which we then look out for in
+ * GHC.Conc.asyncRead.
+ */
+ dw = GetLastError();
+ if ( dw == ERROR_OPERATION_ABORTED ) {
+ /* Only do the retry when dealing with the standard input handle. */
+ HANDLE h = (HANDLE)GetStdHandle(STD_INPUT_HANDLE);
+ if ( _get_osfhandle(work->workData.ioData.fd) == (long)h ) {
+ errCode = (DWORD)-2;
+ }
+ }
+ }