merge uv_tcp_listen and uv_pipe_listen into uv_listen

This commit is contained in:
Igor Zinkovsky 2011-07-22 15:32:27 -07:00
parent 84ebddad88
commit e7497227bd
14 changed files with 100 additions and 66 deletions

View File

@ -76,7 +76,7 @@ typedef void (*uv_read_cb)(uv_stream_t* tcp, ssize_t nread, uv_buf_t buf);
typedef void (*uv_write_cb)(uv_write_t* req, int status); typedef void (*uv_write_cb)(uv_write_t* req, int status);
typedef void (*uv_connect_cb)(uv_connect_t* req, int status); typedef void (*uv_connect_cb)(uv_connect_t* req, int status);
typedef void (*uv_shutdown_cb)(uv_shutdown_t* req, int status); typedef void (*uv_shutdown_cb)(uv_shutdown_t* req, int status);
typedef void (*uv_connection_cb)(uv_handle_t* server, int status); typedef void (*uv_connection_cb)(uv_stream_t* server, int status);
typedef void (*uv_close_cb)(uv_handle_t* handle); typedef void (*uv_close_cb)(uv_handle_t* handle);
typedef void (*uv_timer_cb)(uv_timer_t* handle, int status); typedef void (*uv_timer_cb)(uv_timer_t* handle, int status);
/* TODO: do these really need a status argument? */ /* TODO: do these really need a status argument? */
@ -244,6 +244,8 @@ struct uv_stream_s {
UV_STREAM_FIELDS UV_STREAM_FIELDS
}; };
int uv_listen(uv_stream_t* stream, int backlog, uv_connection_cb cb);
/* This call is used in conjunction with uv_listen() to accept incoming /* This call is used in conjunction with uv_listen() to accept incoming
* connections. Call uv_accept after receiving a uv_connection_cb to accept * connections. Call uv_accept after receiving a uv_connection_cb to accept
* the connection. Before calling uv_accept use uv_*_init() must be * the connection. Before calling uv_accept use uv_*_init() must be
@ -254,7 +256,7 @@ struct uv_stream_s {
* once, it may fail. It is suggested to only call uv_accept once per * once, it may fail. It is suggested to only call uv_accept once per
* uv_connection_cb call. * uv_connection_cb call.
*/ */
int uv_accept(uv_handle_t* server, uv_stream_t* client); int uv_accept(uv_stream_t* server, uv_stream_t* client);
/* Read data from an incoming stream. The callback will be made several /* Read data from an incoming stream. The callback will be made several
* several times until there is no more data to read or uv_read_stop is * several times until there is no more data to read or uv_read_stop is
@ -332,8 +334,6 @@ int uv_tcp_connect(uv_connect_t* req, uv_tcp_t* handle,
int uv_tcp_connect6(uv_connect_t* req, uv_tcp_t* handle, int uv_tcp_connect6(uv_connect_t* req, uv_tcp_t* handle,
struct sockaddr_in6 address, uv_connect_cb cb); struct sockaddr_in6 address, uv_connect_cb cb);
int uv_tcp_listen(uv_tcp_t* handle, int backlog, uv_connection_cb cb);
int uv_getsockname(uv_tcp_t* handle, struct sockaddr* name, int* namelen); int uv_getsockname(uv_tcp_t* handle, struct sockaddr* name, int* namelen);
@ -350,8 +350,6 @@ int uv_pipe_init(uv_pipe_t* handle);
int uv_pipe_bind(uv_pipe_t* handle, const char* name); int uv_pipe_bind(uv_pipe_t* handle, const char* name);
int uv_pipe_listen(uv_pipe_t* handle, uv_connection_cb cb);
int uv_pipe_connect(uv_connect_t* req, uv_pipe_t* handle, int uv_pipe_connect(uv_connect_t* req, uv_pipe_t* handle,
const char* name, uv_connect_cb cb); const char* name, uv_connect_cb cb);

View File

@ -72,6 +72,8 @@ static int uv__stream_open(uv_stream_t*, int fd);
static void uv__finish_close(uv_handle_t* handle); static void uv__finish_close(uv_handle_t* handle);
static uv_err_t uv_err_new(uv_handle_t* handle, int sys_error); static uv_err_t uv_err_new(uv_handle_t* handle, int sys_error);
static int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb);
static int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb);
static uv_write_t* uv__write(uv_stream_t* stream); static uv_write_t* uv__write(uv_stream_t* stream);
static void uv__read(uv_stream_t* stream); static void uv__read(uv_stream_t* stream);
static void uv__stream_connect(uv_stream_t*); static void uv__stream_connect(uv_stream_t*);
@ -432,12 +434,12 @@ void uv__server_io(EV_P_ ev_io* watcher, int revents) {
return; return;
} else { } else {
uv_err_new((uv_handle_t*)stream, errno); uv_err_new((uv_handle_t*)stream, errno);
stream->connection_cb((uv_handle_t*)stream, -1); stream->connection_cb((uv_stream_t*)stream, -1);
} }
} else { } else {
stream->accepted_fd = fd; stream->accepted_fd = fd;
stream->connection_cb((uv_handle_t*)stream, 0); stream->connection_cb((uv_stream_t*)stream, 0);
if (stream->accepted_fd >= 0) { if (stream->accepted_fd >= 0) {
/* The user hasn't yet accepted called uv_accept() */ /* The user hasn't yet accepted called uv_accept() */
ev_io_stop(EV_DEFAULT_ &stream->read_watcher); ev_io_stop(EV_DEFAULT_ &stream->read_watcher);
@ -448,7 +450,7 @@ void uv__server_io(EV_P_ ev_io* watcher, int revents) {
} }
int uv_accept(uv_handle_t* server, uv_stream_t* client) { int uv_accept(uv_stream_t* server, uv_stream_t* client) {
uv_stream_t* streamServer; uv_stream_t* streamServer;
uv_stream_t* streamClient; uv_stream_t* streamClient;
int saved_errno; int saved_errno;
@ -461,7 +463,7 @@ int uv_accept(uv_handle_t* server, uv_stream_t* client) {
streamClient = (uv_stream_t*)client; streamClient = (uv_stream_t*)client;
if (streamServer->accepted_fd < 0) { if (streamServer->accepted_fd < 0) {
uv_err_new(server, EAGAIN); uv_err_new((uv_handle_t*)server, EAGAIN);
goto out; goto out;
} }
@ -482,7 +484,20 @@ out:
} }
int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb) { int uv_listen(uv_stream_t* stream, int backlog, uv_connection_cb cb) {
switch (stream->type) {
case UV_TCP:
return uv_tcp_listen((uv_tcp_t*)stream, backlog, cb);
case UV_NAMED_PIPE:
return uv_pipe_listen((uv_pipe_t*)stream, backlog, cb);
default:
assert(0);
return -1;
}
}
static int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb) {
int r; int r;
int fd; int fd;
@ -1873,7 +1888,7 @@ out:
} }
int uv_pipe_listen(uv_pipe_t* handle, uv_connection_cb cb) { static int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb) {
int saved_errno; int saved_errno;
int status; int status;
@ -1886,7 +1901,7 @@ int uv_pipe_listen(uv_pipe_t* handle, uv_connection_cb cb) {
} }
assert(handle->fd >= 0); assert(handle->fd >= 0);
if ((status = listen(handle->fd, SOMAXCONN)) == -1) { if ((status = listen(handle->fd, backlog)) == -1) {
uv_err_new((uv_handle_t*)handle, errno); uv_err_new((uv_handle_t*)handle, errno);
} else { } else {
handle->connection_cb = cb; handle->connection_cb = cb;
@ -1987,7 +2002,7 @@ static void uv__pipe_accept(EV_P_ ev_io* watcher, int revents) {
} }
} else { } else {
pipe->accepted_fd = sockfd; pipe->accepted_fd = sockfd;
pipe->connection_cb((uv_handle_t*)pipe, 0); pipe->connection_cb((uv_stream_t*)pipe, 0);
if (pipe->accepted_fd == sockfd) { if (pipe->accepted_fd == sockfd) {
/* The user hasn't yet accepted called uv_accept() */ /* The user hasn't yet accepted called uv_accept() */
ev_io_stop(EV_DEFAULT_ &pipe->read_watcher); ev_io_stop(EV_DEFAULT_ &pipe->read_watcher);

View File

@ -144,6 +144,7 @@ void uv_winsock_startup();
void uv_tcp_endgame(uv_tcp_t* handle); void uv_tcp_endgame(uv_tcp_t* handle);
int uv_tcp_listen(uv_tcp_t* handle, int backlog, uv_connection_cb cb);
int uv_tcp_accept(uv_tcp_t* server, uv_tcp_t* client); int uv_tcp_accept(uv_tcp_t* server, uv_tcp_t* client);
int uv_tcp_read_start(uv_tcp_t* handle, uv_alloc_cb alloc_cb, int uv_tcp_read_start(uv_tcp_t* handle, uv_alloc_cb alloc_cb,
uv_read_cb read_cb); uv_read_cb read_cb);
@ -162,6 +163,7 @@ void uv_process_tcp_connect_req(uv_tcp_t* handle, uv_connect_t* req);
void close_pipe(uv_pipe_t* handle, int* status, uv_err_t* err); void close_pipe(uv_pipe_t* handle, int* status, uv_err_t* err);
void uv_pipe_endgame(uv_pipe_t* handle); void uv_pipe_endgame(uv_pipe_t* handle);
int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb);
int uv_pipe_accept(uv_pipe_t* server, uv_pipe_t* client); int uv_pipe_accept(uv_pipe_t* server, uv_pipe_t* client);
int uv_pipe_read_start(uv_pipe_t* handle, uv_alloc_cb alloc_cb, int uv_pipe_read_start(uv_pipe_t* handle, uv_alloc_cb alloc_cb,
uv_read_cb read_cb); uv_read_cb read_cb);

View File

@ -416,7 +416,7 @@ int uv_pipe_accept(uv_pipe_t* server, uv_pipe_t* client) {
/* Starts listening for connections for the given pipe. */ /* Starts listening for connections for the given pipe. */
int uv_pipe_listen(uv_pipe_t* handle, uv_connection_cb cb) { int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb) {
int i, errno; int i, errno;
if (handle->flags & UV_HANDLE_BIND_ERROR) { if (handle->flags & UV_HANDLE_BIND_ERROR) {
@ -678,7 +678,7 @@ void uv_process_pipe_accept_req(uv_pipe_t* handle, uv_req_t* raw_req) {
handle->pending_accepts = req; handle->pending_accepts = req;
if (handle->connection_cb) { if (handle->connection_cb) {
handle->connection_cb((uv_handle_t*)handle, 0); handle->connection_cb((uv_stream_t*)handle, 0);
} }
} else { } else {
if (req->pipeHandle != INVALID_HANDLE_VALUE) { if (req->pipeHandle != INVALID_HANDLE_VALUE) {

View File

@ -48,27 +48,44 @@ void uv_connection_init(uv_stream_t* handle) {
} }
int uv_accept(uv_handle_t* server, uv_stream_t* client) { int uv_listen(uv_stream_t* stream, int backlog, uv_connection_cb cb) {
switch (stream->type) {
case UV_TCP:
return uv_tcp_listen((uv_tcp_t*)stream, backlog, cb);
case UV_NAMED_PIPE:
return uv_pipe_listen((uv_pipe_t*)stream, backlog, cb);
default:
assert(0);
return -1;
}
}
int uv_accept(uv_stream_t* server, uv_stream_t* client) {
assert(client->type == server->type); assert(client->type == server->type);
if (server->type == UV_TCP) { switch (server->type) {
return uv_tcp_accept((uv_tcp_t*)server, (uv_tcp_t*)client); case UV_TCP:
} else if (server->type == UV_NAMED_PIPE) { return uv_tcp_accept((uv_tcp_t*)server, (uv_tcp_t*)client);
return uv_pipe_accept((uv_pipe_t*)server, (uv_pipe_t*)client); case UV_NAMED_PIPE:
return uv_pipe_accept((uv_pipe_t*)server, (uv_pipe_t*)client);
default:
assert(0);
return -1;
} }
return -1;
} }
int uv_read_start(uv_stream_t* handle, uv_alloc_cb alloc_cb, uv_read_cb read_cb) { int uv_read_start(uv_stream_t* handle, uv_alloc_cb alloc_cb, uv_read_cb read_cb) {
if (handle->type == UV_TCP) { switch (handle->type) {
return uv_tcp_read_start((uv_tcp_t*)handle, alloc_cb, read_cb); case UV_TCP:
} else if (handle->type == UV_NAMED_PIPE) { return uv_tcp_read_start((uv_tcp_t*)handle, alloc_cb, read_cb);
return uv_pipe_read_start((uv_pipe_t*)handle, alloc_cb, read_cb); case UV_NAMED_PIPE:
return uv_pipe_read_start((uv_pipe_t*)handle, alloc_cb, read_cb);
default:
assert(0);
return -1;
} }
return -1;
} }
@ -81,14 +98,16 @@ int uv_read_stop(uv_stream_t* handle) {
int uv_write(uv_write_t* req, uv_stream_t* handle, uv_buf_t bufs[], int bufcnt, int uv_write(uv_write_t* req, uv_stream_t* handle, uv_buf_t bufs[], int bufcnt,
uv_write_cb cb) { uv_write_cb cb) {
if (handle->type == UV_TCP) { switch (handle->type) {
return uv_tcp_write(req, (uv_tcp_t*) handle, bufs, bufcnt, cb); case UV_TCP:
} else if (handle->type == UV_NAMED_PIPE) { return uv_tcp_write(req, (uv_tcp_t*) handle, bufs, bufcnt, cb);
return uv_pipe_write(req, (uv_pipe_t*) handle, bufs, bufcnt, cb); case UV_NAMED_PIPE:
return uv_pipe_write(req, (uv_pipe_t*) handle, bufs, bufcnt, cb);
default:
assert(0);
uv_set_sys_error(WSAEINVAL);
return -1;
} }
uv_set_sys_error(WSAEINVAL);
return -1;
} }

View File

@ -842,7 +842,7 @@ void uv_process_tcp_accept_req(uv_tcp_t* handle, uv_req_t* req) {
handle->flags &= ~UV_HANDLE_LISTENING; handle->flags &= ~UV_HANDLE_LISTENING;
if (handle->connection_cb) { if (handle->connection_cb) {
LOOP->last_error = req->error; LOOP->last_error = req->error;
handle->connection_cb((uv_handle_t*)handle, -1); handle->connection_cb((uv_stream_t*)handle, -1);
} }
} }
} else if (req->error.code == UV_OK && } else if (req->error.code == UV_OK &&
@ -853,7 +853,7 @@ void uv_process_tcp_accept_req(uv_tcp_t* handle, uv_req_t* req) {
sizeof(handle->socket)) == 0) { sizeof(handle->socket)) == 0) {
/* Accept and SO_UPDATE_ACCEPT_CONTEXT were successful. */ /* Accept and SO_UPDATE_ACCEPT_CONTEXT were successful. */
if (handle->connection_cb) { if (handle->connection_cb) {
handle->connection_cb((uv_handle_t*)handle, 0); handle->connection_cb((uv_stream_t*)handle, 0);
} }
} else { } else {
/* Error related to accepted socket is ignored because the server */ /* Error related to accepted socket is ignored because the server */

View File

@ -47,7 +47,7 @@ static void buf_free(uv_buf_t uv_buf_t);
static uv_tcp_t tcpServer; static uv_tcp_t tcpServer;
static uv_pipe_t pipeServer; static uv_pipe_t pipeServer;
static uv_handle_t* server; static uv_stream_t* server;
static struct sockaddr_in listen_addr; static struct sockaddr_in listen_addr;
static struct sockaddr_in connect_addr; static struct sockaddr_in connect_addr;
@ -143,7 +143,7 @@ void read_sockets_close_cb(uv_handle_t* handle) {
*/ */
if (uv_now() - start_time > 1000 && read_sockets == 0) { if (uv_now() - start_time > 1000 && read_sockets == 0) {
read_show_stats(); read_show_stats();
uv_close(server, NULL); uv_close((uv_handle_t*)server, NULL);
} }
} }
@ -266,7 +266,7 @@ static void maybe_connect_some() {
} }
static void connection_cb(uv_handle_t* s, int status) { static void connection_cb(uv_stream_t* s, int status) {
uv_stream_t* stream; uv_stream_t* stream;
int r; int r;
@ -373,12 +373,12 @@ HELPER_IMPL(tcp_pump_server) {
listen_addr = uv_ip4_addr("0.0.0.0", TEST_PORT); listen_addr = uv_ip4_addr("0.0.0.0", TEST_PORT);
/* Server */ /* Server */
server = (uv_handle_t*)&tcpServer; server = (uv_stream_t*)&tcpServer;
r = uv_tcp_init(&tcpServer); r = uv_tcp_init(&tcpServer);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_bind(&tcpServer, listen_addr); r = uv_tcp_bind(&tcpServer, listen_addr);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&tcpServer, MAX_WRITE_HANDLES, connection_cb); r = uv_listen((uv_stream_t*)&tcpServer, MAX_WRITE_HANDLES, connection_cb);
ASSERT(r == 0); ASSERT(r == 0);
uv_run(); uv_run();
@ -394,12 +394,12 @@ HELPER_IMPL(pipe_pump_server) {
uv_init(); uv_init();
/* Server */ /* Server */
server = (uv_handle_t*)&pipeServer; server = (uv_stream_t*)&pipeServer;
r = uv_pipe_init(&pipeServer); r = uv_pipe_init(&pipeServer);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_pipe_bind(&pipeServer, TEST_PIPENAME); r = uv_pipe_bind(&pipeServer, TEST_PIPENAME);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_pipe_listen(&pipeServer, connection_cb); r = uv_listen((uv_stream_t*)&pipeServer, MAX_WRITE_HANDLES, connection_cb);
ASSERT(r == 0); ASSERT(r == 0);
uv_run(); uv_run();

View File

@ -55,7 +55,7 @@ static void after_write(uv_write_t* req, int status);
static void after_read(uv_stream_t*, ssize_t nread, uv_buf_t buf); static void after_read(uv_stream_t*, ssize_t nread, uv_buf_t buf);
static void on_close(uv_handle_t* peer); static void on_close(uv_handle_t* peer);
static void on_server_close(uv_handle_t* handle); static void on_server_close(uv_handle_t* handle);
static void on_connection(uv_handle_t*, int status); static void on_connection(uv_stream_t*, int status);
#define WRITE_BUF_LEN (64*1024) #define WRITE_BUF_LEN (64*1024)
#define DNSREC_LEN (4) #define DNSREC_LEN (4)
@ -255,7 +255,7 @@ static uv_buf_t buf_alloc(uv_stream_t* handle, size_t suggested_size) {
} }
static void on_connection(uv_handle_t* server, int status) { static void on_connection(uv_stream_t* server, int status) {
dnshandle* handle; dnshandle* handle;
int r; int r;
@ -302,7 +302,7 @@ static int dns_start(int port) {
return 1; return 1;
} }
r = uv_tcp_listen(&server, 128, on_connection); r = uv_listen((uv_stream_t*)&server, 128, on_connection);
if (r) { if (r) {
/* TODO: Error codes */ /* TODO: Error codes */
fprintf(stderr, "Listen error\n"); fprintf(stderr, "Listen error\n");

View File

@ -39,7 +39,7 @@ static void after_write(uv_write_t* req, int status);
static void after_read(uv_stream_t*, ssize_t nread, uv_buf_t buf); static void after_read(uv_stream_t*, ssize_t nread, uv_buf_t buf);
static void on_close(uv_handle_t* peer); static void on_close(uv_handle_t* peer);
static void on_server_close(uv_handle_t* handle); static void on_server_close(uv_handle_t* handle);
static void on_connection(uv_handle_t*, int status); static void on_connection(uv_stream_t*, int status);
static void after_write(uv_write_t* req, int status) { static void after_write(uv_write_t* req, int status) {
@ -123,7 +123,7 @@ static uv_buf_t echo_alloc(uv_stream_t* handle, size_t suggested_size) {
} }
static void on_connection(uv_handle_t* server, int status) { static void on_connection(uv_stream_t* server, int status) {
uv_stream_t* stream; uv_stream_t* stream;
int r; int r;
@ -187,7 +187,7 @@ static int tcp4_echo_start(int port) {
return 1; return 1;
} }
r = uv_tcp_listen(&tcpServer, 128, on_connection); r = uv_listen((uv_stream_t*)&tcpServer, 128, on_connection);
if (r) { if (r) {
/* TODO: Error codes */ /* TODO: Error codes */
fprintf(stderr, "Listen error\n"); fprintf(stderr, "Listen error\n");
@ -220,7 +220,7 @@ static int tcp6_echo_start(int port) {
return 0; return 0;
} }
r = uv_tcp_listen(&tcpServer, 128, on_connection); r = uv_listen((uv_stream_t*)&tcpServer, 128, on_connection);
if (r) { if (r) {
/* TODO: Error codes */ /* TODO: Error codes */
fprintf(stderr, "Listen error\n"); fprintf(stderr, "Listen error\n");
@ -249,7 +249,7 @@ static int pipe_echo_start(char* pipeName) {
return 1; return 1;
} }
r = uv_pipe_listen(&pipeServer, on_connection); r = uv_listen((uv_stream_t*)&pipeServer, SOMAXCONN, on_connection);
if (r) { if (r) {
fprintf(stderr, "uv_pipe_listen: %s\n", uv_strerror(uv_last_error())); fprintf(stderr, "uv_pipe_listen: %s\n", uv_strerror(uv_last_error()));
return 1; return 1;

View File

@ -63,7 +63,7 @@ static void do_accept(uv_timer_t* timer_handle, int status) {
tcpcnt = uv_counters()->tcp_init; tcpcnt = uv_counters()->tcp_init;
server = (uv_tcp_t*)timer_handle->data; server = (uv_tcp_t*)timer_handle->data;
r = uv_accept((uv_handle_t*)server, (uv_stream_t*)accepted_handle); r = uv_accept((uv_stream_t*)server, (uv_stream_t*)accepted_handle);
ASSERT(r == 0); ASSERT(r == 0);
ASSERT(uv_counters()->tcp_init == tcpcnt); ASSERT(uv_counters()->tcp_init == tcpcnt);
@ -83,7 +83,7 @@ static void do_accept(uv_timer_t* timer_handle, int status) {
} }
static void connection_cb(uv_handle_t* tcp, int status) { static void connection_cb(uv_stream_t* tcp, int status) {
int r; int r;
uv_timer_t* timer_handle; uv_timer_t* timer_handle;
@ -120,7 +120,7 @@ static void start_server() {
r = uv_tcp_bind(server, addr); r = uv_tcp_bind(server, addr);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(server, 128, connection_cb); r = uv_listen((uv_stream_t*)server, 128, connection_cb);
ASSERT(r == 0); ASSERT(r == 0);
} }

View File

@ -67,7 +67,7 @@ static void after_read(uv_stream_t* handle, ssize_t nread, uv_buf_t buf) {
} }
static void on_connection(uv_handle_t* server, int status) { static void on_connection(uv_stream_t* server, int status) {
struct sockaddr sockname; struct sockaddr sockname;
int namelen = sizeof(sockname); int namelen = sizeof(sockname);
uv_handle_t* handle; uv_handle_t* handle;
@ -141,7 +141,7 @@ static int tcp_listener(int port) {
return 1; return 1;
} }
r = uv_tcp_listen(&tcpServer, 128, on_connection); r = uv_listen((uv_stream_t*)&tcpServer, 128, on_connection);
if (r) { if (r) {
fprintf(stderr, "Listen error\n"); fprintf(stderr, "Listen error\n");
return 1; return 1;

View File

@ -59,9 +59,9 @@ TEST_IMPL(pipe_bind_error_addrinuse) {
ASSERT(uv_last_error().code == UV_EADDRINUSE); ASSERT(uv_last_error().code == UV_EADDRINUSE);
r = uv_pipe_listen(&server1, NULL); r = uv_listen((uv_stream_t*)&server1, SOMAXCONN, NULL);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_pipe_listen(&server2, NULL); r = uv_listen((uv_stream_t*)&server2, SOMAXCONN, NULL);
ASSERT(r == -1); ASSERT(r == -1);
ASSERT(uv_last_error().code == UV_EADDRINUSE); ASSERT(uv_last_error().code == UV_EADDRINUSE);
@ -133,7 +133,7 @@ TEST_IMPL(pipe_listen_without_bind) {
r = uv_pipe_init(&server); r = uv_pipe_init(&server);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_pipe_listen(&server, NULL); r = uv_listen((uv_stream_t*)&server, SOMAXCONN, NULL);
ASSERT(r == -1); ASSERT(r == -1);
ASSERT(uv_last_error().code == UV_ENOTCONN); ASSERT(uv_last_error().code == UV_ENOTCONN);

View File

@ -51,9 +51,9 @@ TEST_IMPL(tcp_bind_error_addrinuse) {
r = uv_tcp_bind(&server2, addr); r = uv_tcp_bind(&server2, addr);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&server1, 128, NULL); r = uv_listen((uv_stream_t*)&server1, 128, NULL);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&server2, 128, NULL); r = uv_listen((uv_stream_t*)&server2, 128, NULL);
ASSERT(r == -1); ASSERT(r == -1);
ASSERT(uv_last_error().code == UV_EADDRINUSE); ASSERT(uv_last_error().code == UV_EADDRINUSE);
@ -197,7 +197,7 @@ TEST_IMPL(tcp_listen_without_bind) {
uv_init(); uv_init();
r = uv_tcp_init(&server); r = uv_tcp_init(&server);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&server, 128, NULL); r = uv_listen((uv_stream_t*)&server, 128, NULL);
ASSERT(r == 0); ASSERT(r == 0);
return 0; return 0;

View File

@ -51,9 +51,9 @@ TEST_IMPL(tcp_bind6_error_addrinuse) {
r = uv_tcp_bind6(&server2, addr); r = uv_tcp_bind6(&server2, addr);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&server1, 128, NULL); r = uv_listen((uv_stream_t*)&server1, 128, NULL);
ASSERT(r == 0); ASSERT(r == 0);
r = uv_tcp_listen(&server2, 128, NULL); r = uv_listen((uv_stream_t*)&server2, 128, NULL);
ASSERT(r == -1); ASSERT(r == -1);
ASSERT(uv_last_error().code == UV_EADDRINUSE); ASSERT(uv_last_error().code == UV_EADDRINUSE);