The early exit logic in this function is a bit suboptimal -- we don't
need to close the @fd if we haven't even opened it, and since all errors
are fatal, we don't need to bump the progress counter. The logic in
this function is about to get more involved due to the addition of the
directory tree structure checker, so clean up these warts.
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
if (bstat->bs_xflags & FS_XFLAG_HASATTR) {
error = check_xattr_names(ctx, &dsc, handle, bstat);
if (error)
- goto out;
+ goto err;
}
/*
if (error == ESTALE)
return ESTALE;
str_errno(ctx, descr_render(&dsc));
- goto out;
+ goto err;
}
error = check_dirent_names(ctx, &dsc, &fd, bstat);
if (error)
- goto out;
+ goto err_fd;
}
-out:
progress_add(1);
+err_fd:
if (fd >= 0) {
err2 = close(fd);
if (err2)
if (!error && err2)
error = err2;
}
-
+err:
if (error)
*aborted = true;
if (!error && *aborted)