From eab089bc9420386a38dfa01872edc62480f4e27f Mon Sep 17 00:00:00 2001 From: sin Date: Tue, 16 Sep 2014 13:53:40 +0100 Subject: Detect and cleanup stale transfers --- ratatox.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'ratatox.c') diff --git a/ratatox.c b/ratatox.c index af863cc..ea3fe74 100644 --- a/ratatox.c +++ b/ratatox.c @@ -911,6 +911,19 @@ loop(void) exit(EXIT_FAILURE); } + /* Check for broken transfers, i.e. the friend went offline + * in the middle of a transfer. + */ + TAILQ_FOREACH(f, &friendhead, entry) { + if (tox_get_friend_connection_status(tox, f->fid) == 0) { + if (f->t.state != TRANSFER_NONE) { + printout("Stale transfer detected, friend offline\n"); + f->t.state = TRANSFER_NONE; + free(f->t.buf); + } + } + } + /* If we hit the receiver too hard, we will run out of * local buffer slots. In that case tox_file_send_data() * will return -1 and we will have to queue the buffer to -- cgit v1.2.3