From b4de848d75b5bc289f13c4f47a4f78d4c876b1a2 Mon Sep 17 00:00:00 2001 From: Wayne Davison Date: Sun, 9 Nov 2008 17:59:11 -0800 Subject: [PATCH] Avoid a potential hang when --remove-*-files is active. --- io.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/io.c b/io.c index a4e24357..ff320062 100644 --- a/io.c +++ b/io.c @@ -447,9 +447,14 @@ static void read_msg_fd(void) * this, sender-side deletions were mostly happening at the end. */ void increment_active_files(int ndx, int itemizing, enum logcode code) { - /* TODO: tune these limits? */ - while (active_filecnt >= (active_bytecnt >= 128*1024 ? 10 : 50)) { + while (1) { + /* TODO: tune these limits? */ + int limit = active_bytecnt >= 128*1024 ? 10 : 50; + if (active_filecnt < limit) + break; check_for_finished_files(itemizing, code, 0); + if (active_filecnt < limit) + break; if (iobuf_out_cnt) io_flush(NORMAL_FLUSH); else -- 2.34.1