diff options
author | Christopher Faylor <me@cgf.cx> | 2002-12-14 04:01:32 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2002-12-14 04:01:32 +0000 |
commit | 8bce0d723c50924b908dca1467037c8008e872be (patch) | |
tree | dcaf982175c090c0e7668af5fa00dac09fb07b27 /winsup/cygwin/fhandler_tty.cc | |
parent | ec085641a9b4d25e16df12d7449f7ad689934117 (diff) | |
download | cygnal-8bce0d723c50924b908dca1467037c8008e872be.tar.gz cygnal-8bce0d723c50924b908dca1467037c8008e872be.tar.bz2 cygnal-8bce0d723c50924b908dca1467037c8008e872be.zip |
Throughout, change fhandler_*::read and fhandler_*::raw_read to void functions
whose second arguments are both the lenght and the return value.
* fhandler.cc (fhandler_base::read): Rework slightly to use second argument as
input/output. Tweak CRLF stuff.
(fhandler_base::readv): Accommodate fhandler_*::read changes.
* cygthread.h (cygthread::detach): Declare as taking optional handle argument.
(cygthread::detach): When given a handle argument, wait for the handle to be
signalled before waiting for thread to detach. Return true when signal
detected.
Diffstat (limited to 'winsup/cygwin/fhandler_tty.cc')
-rw-r--r-- | winsup/cygwin/fhandler_tty.cc | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/winsup/cygwin/fhandler_tty.cc b/winsup/cygwin/fhandler_tty.cc index 3b47f567a..60918f6bd 100644 --- a/winsup/cygwin/fhandler_tty.cc +++ b/winsup/cygwin/fhandler_tty.cc @@ -199,8 +199,8 @@ process_input (void *) while (1) { - int nraw = tty_master->console->read ((void *) rawbuf, - (size_t) INP_BUFFER_SIZE); + size_t nraw = INP_BUFFER_SIZE; + tty_master->console->read ((void *) rawbuf, nraw); (void) tty_master->line_edit (rawbuf, nraw); } } @@ -634,8 +634,8 @@ fhandler_tty_slave::write (const void *ptr, size_t len) return towrite; } -int __stdcall -fhandler_tty_slave::read (void *ptr, size_t len) +void __stdcall +fhandler_tty_slave::read (void *ptr, size_t& len) { int totalread = 0; int vmin = 0; @@ -692,7 +692,8 @@ fhandler_tty_slave::read (void *ptr, size_t len) if (totalread > 0) break; set_sig_errno (EINTR); - return -1; + (ssize_t) len = -1; + return; } rc = WaitForSingleObject (input_mutex, 1000); @@ -716,7 +717,8 @@ fhandler_tty_slave::read (void *ptr, size_t len) if (!vmin && !time_to_wait) { ReleaseMutex (input_mutex); - return bytes_in_pipe; + (ssize_t) len = bytes_in_pipe; + return; } readlen = min (bytes_in_pipe, min (len, sizeof (buf))); @@ -795,7 +797,8 @@ fhandler_tty_slave::read (void *ptr, size_t len) waiter = time_to_wait; } termios_printf ("%d=read(%x, %d)", totalread, ptr, len); - return totalread; + (ssize_t) len = totalread; + return; } int @@ -1085,10 +1088,11 @@ fhandler_pty_master::write (const void *ptr, size_t len) return i; } -int __stdcall -fhandler_pty_master::read (void *ptr, size_t len) +void __stdcall +fhandler_pty_master::read (void *ptr, size_t& len) { - return process_slave_output ((char *) ptr, len, pktmode); + (ssize_t) len = process_slave_output ((char *) ptr, len, pktmode); + return; } int |