1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Revert "Use given connections id in connection_disappeared()."

This reverts src/{network,sched}/connection.c CVS revision 1.43,
which was made on 2003-07-03 and converted to Git commit
cae65f7941628109b51ffb2e2d05882fbbdc73ef in elinks-history.

It is pointless to check whether (c == d && c->id == d->id).
If c == d, then surely c->id == d->id, and I wouldn't be surprised
to see a compiler optimize that out.
Whereas, by taking the id as a parameter, connection_disappeared()
can check whether the pointer now points to a new struct connection
with a different id.
This commit is contained in:
Kalle Olavi Niemitalo 2008-10-04 13:00:57 +03:00 committed by Kalle Olavi Niemitalo
parent 22975bb0ec
commit bda58a124a

View File

@ -118,13 +118,19 @@ get_connections_transfering_count(void)
return i;
}
/** Check whether the pointer @a conn still points to a connection
* with the given @a id. If the struct connection has already been
* freed, this returns 0. By comparing connection.id, this function
* can usually detect even the case where a different connection has
* been created at the same address. For that to work, the caller
* must save the connection.id before the connection can be deleted. */
static inline int
connection_disappeared(struct connection *conn)
connection_disappeared(struct connection *conn, unsigned int id)
{
struct connection *c;
foreach (c, connection_queue)
if (conn == c && conn->id == c->id)
if (conn == c && id == c->id)
return 0;
return 1;
@ -349,9 +355,11 @@ set_connection_state(struct connection *conn, struct connection_state state)
conn->state = state;
if (is_in_state(conn->state, S_TRANS)) {
if (progress->timer == TIMER_ID_UNDEF) {
const unsigned int id = conn->id;
start_update_progress(progress, (void (*)(void *)) stat_timer, conn);
update_connection_progress(conn);
if (connection_disappeared(conn))
if (connection_disappeared(conn, id))
return;
}
@ -420,13 +428,15 @@ void
notify_connection_callbacks(struct connection *conn)
{
struct connection_state state = conn->state;
unsigned int id = conn->id;
struct download *download, *next;
foreachsafe (download, next, conn->downloads) {
download->cached = conn->cached;
if (download->callback)
download->callback(download, download->data);
if (is_in_progress_state(state) && connection_disappeared(conn))
if (is_in_progress_state(state)
&& connection_disappeared(conn, id))
return;
}
}