1
0
mirror of https://github.com/irssi/irssi.git synced 2024-12-04 14:46:39 -05:00

Blocking sockets (win32) shouldn't block irssi entirely now.

git-svn-id: http://svn.irssi.org/repos/irssi/trunk@991 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
Timo Sirainen 2000-12-15 19:44:27 +00:00 committed by cras
parent f6efe1cad8
commit 4ea69f3059

View File

@ -36,6 +36,12 @@ static int signal_default_event;
static int signal_server_event; static int signal_server_event;
static int signal_server_incoming; static int signal_server_incoming;
#ifdef BLOCKING_SOCKETS
# define MAX_SOCKET_READS 1
#else
# define MAX_SOCKET_READS 5
#endif
static void cmd_send(IRC_SERVER_REC *server, const char *cmd, int send_now, int immediate) static void cmd_send(IRC_SERVER_REC *server, const char *cmd, int send_now, int immediate)
{ {
char str[513], *ptr; char str[513], *ptr;
@ -341,10 +347,10 @@ static void irc_parse_incoming(SERVER_REC *server)
g_return_if_fail(server != NULL); g_return_if_fail(server != NULL);
/* Some commands can send huge replies and irssi might handle them /* Some commands can send huge replies and irssi might handle them
too slowly, so read only max. 5 times from the socket before too slowly, so read only a few times from the socket before
letting other tasks to run. */ letting other tasks to run. */
count = 0; count = 0;
while (irc_receive_line(server, &str, count < 5) > 0) { while (irc_receive_line(server, &str, count < MAX_SOCKET_READS) > 0) {
rawlog_input(server->rawlog, str); rawlog_input(server->rawlog, str);
signal_emit_id(signal_server_incoming, 2, server, str); signal_emit_id(signal_server_incoming, 2, server, str);