From f4e4dac80163625d0d1713ee8ff6c2d9f0c3d394 Mon Sep 17 00:00:00 2001 From: Nick Mathewson Date: Wed, 3 Mar 2004 05:08:01 +0000 Subject: Implement hold_open_until_flushed. I may have missed something important. svn:r1209 --- src/or/connection.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'src/or/connection.c') diff --git a/src/or/connection.c b/src/or/connection.c index 934543c6d7..30741ebead 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -209,6 +209,27 @@ _connection_mark_for_close(connection_t *conn, char reason) return retval; } +void connection_expire_held_open(void) +{ + connection_t **carray, *conn; + int n, i; + time_t now; + + now = time(NULL); + + get_connection_array(&carray, &n); + for (i = 0; i < n; ++i) { + conn = carray[i]; + /* If we've been holding the connection open, but we haven't written + * for 15 seconds... + */ + if (conn->marked_for_close && conn->hold_open_until_flushed && + now - conn->timestamp_lastwritten >= 15) { + conn->hold_open_until_flushed = 0; + } + } +} + int connection_create_listener(char *bindaddress, uint16_t bindport, int type) { struct sockaddr_in bindaddr; /* where to bind */ struct hostent *rent; -- cgit v1.2.3-54-g00ecf