mirror of
https://github.com/cesanta/mongoose.git
synced 2025-07-29 00:46:16 +08:00
commit
a3b63f3b0d
@ -4339,6 +4339,7 @@ static void settmout(struct mg_connection *c, uint8_t type) {
|
|||||||
: type == MIP_TTYPE_SYN ? MIP_TCP_SYN_MS
|
: type == MIP_TTYPE_SYN ? MIP_TCP_SYN_MS
|
||||||
: type == MIP_TTYPE_FIN ? MIP_TCP_FIN_MS
|
: type == MIP_TTYPE_FIN ? MIP_TCP_FIN_MS
|
||||||
: MIP_TCP_KEEPALIVE_MS;
|
: MIP_TCP_KEEPALIVE_MS;
|
||||||
|
if (s->ttype == MIP_TTYPE_FIN) return; // skip if 3-way closing
|
||||||
s->timer = ifp->now + n;
|
s->timer = ifp->now + n;
|
||||||
s->ttype = type;
|
s->ttype = type;
|
||||||
MG_VERBOSE(("%lu %d -> %llx", c->id, type, s->timer));
|
MG_VERBOSE(("%lu %d -> %llx", c->id, type, s->timer));
|
||||||
@ -5386,7 +5387,6 @@ void mg_mgr_poll(struct mg_mgr *mgr, int ms) {
|
|||||||
if (s->twclosure &&
|
if (s->twclosure &&
|
||||||
(!c->is_tls || (c->rtls.len == 0 && mg_tls_pending(c) == 0)))
|
(!c->is_tls || (c->rtls.len == 0 && mg_tls_pending(c) == 0)))
|
||||||
c->is_closing = 1;
|
c->is_closing = 1;
|
||||||
if (c->is_draining && c->send.len == 0) c->is_closing = 1;
|
|
||||||
if (c->is_closing) close_conn(c);
|
if (c->is_closing) close_conn(c);
|
||||||
}
|
}
|
||||||
(void) ms;
|
(void) ms;
|
||||||
|
@ -177,6 +177,7 @@ static void settmout(struct mg_connection *c, uint8_t type) {
|
|||||||
: type == MIP_TTYPE_SYN ? MIP_TCP_SYN_MS
|
: type == MIP_TTYPE_SYN ? MIP_TCP_SYN_MS
|
||||||
: type == MIP_TTYPE_FIN ? MIP_TCP_FIN_MS
|
: type == MIP_TTYPE_FIN ? MIP_TCP_FIN_MS
|
||||||
: MIP_TCP_KEEPALIVE_MS;
|
: MIP_TCP_KEEPALIVE_MS;
|
||||||
|
if (s->ttype == MIP_TTYPE_FIN) return; // skip if 3-way closing
|
||||||
s->timer = ifp->now + n;
|
s->timer = ifp->now + n;
|
||||||
s->ttype = type;
|
s->ttype = type;
|
||||||
MG_VERBOSE(("%lu %d -> %llx", c->id, type, s->timer));
|
MG_VERBOSE(("%lu %d -> %llx", c->id, type, s->timer));
|
||||||
@ -1224,7 +1225,6 @@ void mg_mgr_poll(struct mg_mgr *mgr, int ms) {
|
|||||||
if (s->twclosure &&
|
if (s->twclosure &&
|
||||||
(!c->is_tls || (c->rtls.len == 0 && mg_tls_pending(c) == 0)))
|
(!c->is_tls || (c->rtls.len == 0 && mg_tls_pending(c) == 0)))
|
||||||
c->is_closing = 1;
|
c->is_closing = 1;
|
||||||
if (c->is_draining && c->send.len == 0) c->is_closing = 1;
|
|
||||||
if (c->is_closing) close_conn(c);
|
if (c->is_closing) close_conn(c);
|
||||||
}
|
}
|
||||||
(void) ms;
|
(void) ms;
|
||||||
|
Loading…
Reference in New Issue
Block a user