diff options
author | Christopher Faylor <me@cgf.cx> | 2000-03-12 04:44:37 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2000-03-12 04:44:37 +0000 |
commit | 774ea162116fcb08278c5efbe287848f5b5dd431 (patch) | |
tree | a124392461f0c8f99c127a7c5b6d880e85d145fd /winsup/cygwin/fhandler_tty.cc | |
parent | 1e8b88023ceb35d74f74640bb5109f7b2a5f34e5 (diff) | |
download | newlib-774ea162116fcb08278c5efbe287848f5b5dd431.zip newlib-774ea162116fcb08278c5efbe287848f5b5dd431.tar.gz newlib-774ea162116fcb08278c5efbe287848f5b5dd431.tar.bz2 |
* fhandler_console.cc (fhandler_console::read): Don't even think about breaking
on interrupt if executing in a "cygwin" thread.
* fhandler_tty.cc (fhandler_pty_master::process_slave_output): Streamline,
simplify code.
* sigproc.cc (sig_send): Remove debugging statement.
Diffstat (limited to 'winsup/cygwin/fhandler_tty.cc')
-rw-r--r-- | winsup/cygwin/fhandler_tty.cc | 226 |
1 files changed, 119 insertions, 107 deletions
diff --git a/winsup/cygwin/fhandler_tty.cc b/winsup/cygwin/fhandler_tty.cc index 3261ea2..14da2bb 100644 --- a/winsup/cygwin/fhandler_tty.cc +++ b/winsup/cygwin/fhandler_tty.cc @@ -154,7 +154,8 @@ void fhandler_pty_master::doecho (const void *str, DWORD len) { acquire_output_mutex (INFINITE); - WriteFile (get_ttyp ()->to_master, str, len, &len, NULL); + if (!WriteFile (get_ttyp ()->to_master, str, len, &len, NULL)) + termios_printf ("Write to %p failed, %E", get_ttyp ()->to_master); // WaitForSingleObject (output_done_event, INFINITE); release_output_mutex (); } @@ -219,135 +220,144 @@ fhandler_pty_master::process_slave_output (char *buf, size_t len) char outbuf[OUT_BUFFER_SIZE]; DWORD n; int column = 0; - -again: + int rc = 0; if (len == 0) - return 0; + goto out; - if (neednl_) + for (;;) { - /* We need to return a left over \n character, resulting from - \r\n conversion. Note that we already checked for FLUSHO and - OutputStopped at the time that we read the character, so we - don't check again here. */ - buf[0] = '\n'; - neednl_ = 0; - return 1; - } + if (neednl_) + { + /* We need to return a left over \n character, resulting from + \r\n conversion. Note that we already checked for FLUSHO and + OutputStopped at the time that we read the character, so we + don't check again here. */ + buf[0] = '\n'; + neednl_ = 0; + rc = 1; + break; + } - /* Set RLEN to the number of bytes to read from the pipe. */ - rlen = len; - if (get_ttyp ()->ti.c_oflag & OPOST && get_ttyp ()->ti.c_oflag & ONLCR) - { - /* We are going to expand \n to \r\n, so don't read more than - half of the number of bytes requested. */ - rlen /= 2; - if (rlen == 0) - rlen = 1; - } - if (rlen > sizeof outbuf) - rlen = sizeof outbuf; + /* Set RLEN to the number of bytes to read from the pipe. */ + rlen = len; + if (get_ttyp ()->ti.c_oflag & OPOST && get_ttyp ()->ti.c_oflag & ONLCR) + { + /* We are going to expand \n to \r\n, so don't read more than + half of the number of bytes requested. */ + rlen /= 2; + if (rlen == 0) + rlen = 1; + } + if (rlen > sizeof outbuf) + rlen = sizeof outbuf; - HANDLE handle = get_io_handle (); + HANDLE handle = get_io_handle (); - /* Doing a busy wait like this is quite inefficient, but nothing - else seems to work completely. Windows should provide some sort - of overlapped I/O for pipes, or something, but it doesn't. */ - DWORD avail; - while (1) - { - if (! PeekNamedPipe (handle, NULL, 0, NULL, &avail, NULL)) + /* Doing a busy wait like this is quite inefficient, but nothing + else seems to work completely. Windows should provide some sort + of overlapped I/O for pipes, or something, but it doesn't. */ + while (1) { - if (GetLastError () == ERROR_BROKEN_PIPE) - return 0; - __seterrno (); - return -1; + DWORD avail; + if (!PeekNamedPipe (handle, NULL, 0, NULL, &avail, NULL)) + goto err; + if (avail > 0) + break; + if (hit_eof ()) + goto out; + Sleep (10); } - if (avail > 0) - break; - if (hit_eof ()) - return 0; - Sleep (10); - } - if (ReadFile (handle, outbuf, rlen, &n, NULL) == FALSE) - { - if (GetLastError () == ERROR_BROKEN_PIPE) - return 0; - __seterrno (); - return -1; - } + if (ReadFile (handle, outbuf, rlen, &n, NULL) == FALSE) + goto err; - termios_printf ("len=%u", n); + termios_printf ("rlen %u", n); - if (get_ttyp ()->ti.c_lflag & FLUSHO) - { - get_ttyp ()->write_retval = n; - if (output_done_event != NULL) - SetEvent (output_done_event); - goto again; - } - - if (get_ttyp ()->OutputStopped) - { - termios_printf ("waiting for restart_output_event"); - WaitForSingleObject (restart_output_event, INFINITE); - } + if (get_ttyp ()->ti.c_lflag & FLUSHO) + { + get_ttyp ()->write_retval = n; + if (output_done_event != NULL) + SetEvent (output_done_event); + continue; + } - if (get_ttyp ()->ti.c_oflag & OPOST) // post-process output - { - char *iptr = outbuf, *optr = buf; + if (get_ttyp ()->OutputStopped) + { + termios_printf ("waiting for restart_output_event"); + WaitForSingleObject (restart_output_event, INFINITE); + termios_printf ("done waiting for restart_output_event"); + } - while (n--) + if (!(get_ttyp ()->ti.c_oflag & OPOST)) // post-process output + { + memcpy (buf, outbuf, n); + rc = n; + } + else // raw output mode { - switch (*iptr) + char *iptr = outbuf, *optr = buf; + + while (n--) { - case '\r': - if ((get_ttyp ()->ti.c_oflag & ONOCR) && column == 0) + switch (*iptr) { - iptr++; - continue; + case '\r': + if ((get_ttyp ()->ti.c_oflag & ONOCR) && column == 0) + { + iptr++; + continue; + } + if (get_ttyp ()->ti.c_oflag & OCRNL) + *iptr = '\n'; + else + column = 0; + break; + case '\n': + if (get_ttyp ()->ti.c_oflag & ONLCR) + { + *optr++ = '\r'; + column = 0; + } + if (get_ttyp ()->ti.c_oflag & ONLRET) + column = 0; + break; + default: + column++; + break; } - if (get_ttyp ()->ti.c_oflag & OCRNL) - *iptr = '\n'; - else - column = 0; - break; - case '\n': - if (get_ttyp ()->ti.c_oflag & ONLCR) + + /* Don't store data past the end of the user's buffer. This + can happen if the user requests a read of 1 byte when + doing \r\n expansion. */ + if (optr - buf >= (int) len) { - *optr++ = '\r'; - column = 0; + neednl_ = 1; + if (*iptr != '\n' || n != 0) + system_printf ("internal error: %d unexpected characters", n); + break; } - if (get_ttyp ()->ti.c_oflag & ONLRET) - column = 0; - break; - default: - column++; - break; - } - /* Don't store data past the end of the user's buffer. This - can happen if the user requests a read of 1 byte when - doing \r\n expansion. */ - if (optr - buf >= (int) len) - { - neednl_ = 1; - if (*iptr != '\n' || n != 0) - system_printf ("internal error: %d unexpected characters", n); - break; + *optr++ = *iptr++; } + rc = optr - buf; + } + break; - *optr++ = *iptr++; + err: + if (GetLastError () == ERROR_BROKEN_PIPE) + rc = 0; + else + { + __seterrno (); + rc = -1; } - return optr - buf; - } - else // raw output mode - { - memcpy (buf, outbuf, n); - return n; + break; } + +out: + termios_printf ("returning %d", rc); + return rc; } static DWORD WINAPI @@ -546,8 +556,10 @@ fhandler_tty_slave::write (const void *ptr, size_t len) if (output_done_event != NULL) { - termios_printf("tty%d waiting for output_done", ttynum); - WaitForSingleObject (output_done_event, n * 1000); + DWORD rc; + DWORD x = n * 1000; + rc = WaitForSingleObject (output_done_event, x); + termios_printf("waited %d ms for output_done_event, WFSO %d", x, rc); } if (get_ttyp ()->write_retval < 0) |