comparison src/event/ngx_event_close.c @ 26:53cb81681040

nginx-0.0.1-2002-12-15-09:25:09 import
author Igor Sysoev <igor@sysoev.ru>
date Sun, 15 Dec 2002 06:25:09 +0000
parents b5481d6fbbd4
children 2ffaa35fba42
comparison
equal deleted inserted replaced
25:a8b156554dfe 26:53cb81681040
9 int ngx_event_close_connection(ngx_event_t *ev) 9 int ngx_event_close_connection(ngx_event_t *ev)
10 { 10 {
11 int rc; 11 int rc;
12 ngx_connection_t *c = (ngx_connection_t *) ev->data; 12 ngx_connection_t *c = (ngx_connection_t *) ev->data;
13 13
14 ngx_log_debug(c->log, "CLOSE: %d" _ c->fd);
15
14 ngx_assert((c->fd != -1), return NGX_ERROR, c->log, 16 ngx_assert((c->fd != -1), return NGX_ERROR, c->log,
15 "ngx_event_close: already closed"); 17 "ngx_event_close: already closed");
16 18
17 ngx_destroy_pool(c->pool); 19 ngx_destroy_pool(c->pool);
18 20
21 ngx_del_event(c->read, NGX_READ_EVENT, NGX_CLOSE_EVENT);
22 ngx_del_event(c->write, NGX_WRITE_EVENT, NGX_CLOSE_EVENT);
23
19 if ((rc = ngx_close_socket(c->fd)) == -1) 24 if ((rc = ngx_close_socket(c->fd)) == -1)
20 ngx_log_error(NGX_LOG_ERR, c->log, ngx_socket_errno, 25 ngx_log_error(NGX_LOG_ERR, c->log, ngx_socket_errno,
21 "ngx_event_close: close failed"); 26 "ngx_event_close: close failed");
22
23 if (c->read->next)
24 ngx_del_event(c->read, NGX_READ_EVENT);
25
26 if (c->write->next)
27 ngx_del_event(c->write, NGX_WRITE_EVENT);
28 27
29 c->fd = -1; 28 c->fd = -1;
30 29
31 return rc; 30 return rc;
32 } 31 }