Cygwin: FIFO: set client handler flags more accurately
Reflect the fact that client handlers are only used for reading and that, after connection, they are always nonblocking.
This commit is contained in:
parent
c12053a793
commit
7ad80b3c23
@ -246,7 +246,8 @@ fhandler_fifo::add_client_handler ()
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
fh->set_handle (ph);
|
fh->set_handle (ph);
|
||||||
fh->set_flags (get_flags ());
|
fh->set_flags ((openflags & ~O_ACCMODE) | O_RDONLY);
|
||||||
|
fh->set_nonblocking (false);
|
||||||
ret = 0;
|
ret = 0;
|
||||||
fc.fh = fh;
|
fc.fh = fh;
|
||||||
fc_handler[nhandlers++] = fc;
|
fc_handler[nhandlers++] = fc;
|
||||||
@ -298,6 +299,7 @@ fhandler_fifo::record_connection (fifo_client_handler& fc)
|
|||||||
fifo_client_lock ();
|
fifo_client_lock ();
|
||||||
fc.state = fc_connected;
|
fc.state = fc_connected;
|
||||||
nconnected++;
|
nconnected++;
|
||||||
|
fc.fh->set_nonblocking (true);
|
||||||
set_pipe_non_blocking (fc.fh->get_handle (), true);
|
set_pipe_non_blocking (fc.fh->get_handle (), true);
|
||||||
fifo_client_unlock ();
|
fifo_client_unlock ();
|
||||||
HANDLE evt = InterlockedExchangePointer (&fc.connect_evt, NULL);
|
HANDLE evt = InterlockedExchangePointer (&fc.connect_evt, NULL);
|
||||||
|
Loading…
Reference in New Issue
Block a user