nbytes = MIN ((channel->rdp + BUFFER_SIZE - channel->wrp - 1) % BUFFER_SIZE,
BUFFER_SIZE - channel->wrp);
+ if (channel->debug)
+ g_print ("thread %#x: calling reader for %d bytes\n",
+ channel->thread_id, nbytes);
+
UNLOCK (channel->mutex);
nbytes = (*channel->reader) (channel->fd, buffer, nbytes);
}
gint
-g_io_channel_win32_poll (GPollFD *fds,
- gint n_fds,
- GIOCondition condition,
- gint timeout)
+g_io_channel_win32_poll (GPollFD *fds,
+ gint n_fds,
+ gint timeout)
{
- int i;
int result;
- gboolean debug = FALSE;
g_return_val_if_fail (n_fds >= 0, 0);
return result;
}
-gint
-g_io_channel_win32_wait_for_condition (GIOChannel *channel,
- GIOCondition condition,
- gint timeout)
+void
+g_io_channel_win32_make_pollfd (GIOChannel *channel,
+ GIOCondition condition,
+ GPollFD *fd)
{
- GPollFD pollfd;
GIOWin32Channel *win32_channel = (GIOWin32Channel *) channel;
- pollfd.fd = (gint) win32_channel->data_avail_event;
- pollfd.events = condition;
+ if (win32_channel->data_avail_event == NULL)
+ create_events (win32_channel);
- return g_io_channel_win32_poll (&pollfd, 1, condition, timeout);
+ fd->fd = (gint) win32_channel->data_avail_event;
+ fd->events = condition;
+
+ if (win32_channel->thread_id == 0)
+ if (win32_channel->type == G_IO_FILE_DESC)
+ create_reader_thread (win32_channel, fd_reader);
+ else if (win32_channel->type == G_IO_STREAM_SOCKET)
+ create_reader_thread (win32_channel, sock_reader);
}
/* This variable and the functions below are present just to be