X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/03dbc0b831c0df53c45828b73ffcb816f84c28bf..2356d73bb400176c957a575fd8f0344d882427b9:/cleanup.c diff --git a/cleanup.c b/cleanup.c index 9cf7be0f..2f47ef7f 100644 --- a/cleanup.c +++ b/cleanup.c @@ -87,25 +87,22 @@ static pid_t cleanup_pid = 0; pid_t cleanup_child_pid = -1; +int in_exit_cleanup = 0; + /** * Eventually calls exit(), passing @p code, therefore does not return. * * @param code one of the RERR_* codes from errcode.h. **/ -void _exit_cleanup(int code, const char *file, int line) +NORETURN void _exit_cleanup(int code, const char *file, int line) { int ocode = code; - static int inside_cleanup = 0; - - if (inside_cleanup > 10) { - /* prevent the occasional infinite recursion */ - return; - } - inside_cleanup++; SIGACTION(SIGUSR1, SIG_IGN); SIGACTION(SIGUSR2, SIG_IGN); + in_exit_cleanup = 1; + if (verbose > 3) { rprintf(FINFO,"_exit_cleanup(code=%d, file=%s, line=%d): entered\n", code, file, line); @@ -113,16 +110,15 @@ void _exit_cleanup(int code, const char *file, int line) if (cleanup_child_pid != -1) { int status; - if (wait_process(cleanup_child_pid, &status, WNOHANG) - == cleanup_child_pid) { + if (wait_process(cleanup_child_pid, &status, WNOHANG) == cleanup_child_pid) { status = WEXITSTATUS(status); if (status > code) code = status; } } - if (cleanup_got_literal && cleanup_new_fname && keep_partial - && handle_partial_dir(cleanup_new_fname, PDIR_CREATE)) { + if (cleanup_got_literal && cleanup_fname && cleanup_new_fname + && keep_partial && handle_partial_dir(cleanup_new_fname, PDIR_CREATE)) { char *fname = cleanup_fname; cleanup_fname = NULL; if (cleanup_fd_r != -1)