btrfs-progs: fi defrag: clean up duplicate code if find errors

In function cmd_filesystem_defrag(), lines of code for error handling
are duplicate and hard to expand in further.

Create a jump label for errors.

Signed-off-by: Su Yue <suy.fnst@cn.fujitsu.com>
Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
Su Yue 2017-11-28 17:14:48 +08:00 committed by David Sterba
parent 6dd8669a1c
commit e9db166287

View File

@ -1029,23 +1029,22 @@ static int cmd_filesystem_defrag(int argc, char **argv)
if (fd < 0) { if (fd < 0) {
error("cannot open %s: %s", argv[i], error("cannot open %s: %s", argv[i],
strerror(errno)); strerror(errno));
defrag_global_errors++; ret = -errno;
close_file_or_dir(fd, dirstream); goto next;
continue;
} }
if (fstat(fd, &st)) {
ret = fstat(fd, &st);
if (ret) {
error("failed to stat %s: %s", error("failed to stat %s: %s",
argv[i], strerror(errno)); argv[i], strerror(errno));
defrag_global_errors++; ret = -errno;
close_file_or_dir(fd, dirstream); goto next;
continue;
} }
if (!(S_ISDIR(st.st_mode) || S_ISREG(st.st_mode))) { if (!(S_ISDIR(st.st_mode) || S_ISREG(st.st_mode))) {
error("%s is not a directory or a regular file", error("%s is not a directory or a regular file",
argv[i]); argv[i]);
defrag_global_errors++; ret = -EINVAL;
close_file_or_dir(fd, dirstream); goto next;
continue;
} }
if (recursive && S_ISDIR(st.st_mode)) { if (recursive && S_ISDIR(st.st_mode)) {
ret = nftw(argv[i], defrag_callback, 10, ret = nftw(argv[i], defrag_callback, 10,
@ -1060,20 +1059,25 @@ static int cmd_filesystem_defrag(int argc, char **argv)
ret = ioctl(fd, BTRFS_IOC_DEFRAG_RANGE, ret = ioctl(fd, BTRFS_IOC_DEFRAG_RANGE,
&defrag_global_range); &defrag_global_range);
defrag_err = errno; defrag_err = errno;
} if (ret && defrag_err == ENOTTY) {
close_file_or_dir(fd, dirstream); error(
if (ret && defrag_err == ENOTTY) {
error(
"defrag range ioctl not supported in this kernel version, 2.6.33 and newer is required"); "defrag range ioctl not supported in this kernel version, 2.6.33 and newer is required");
defrag_global_errors++; defrag_global_errors++;
break; close_file_or_dir(fd, dirstream);
break;
}
if (ret) {
error("defrag failed on %s: %s", argv[i],
strerror(defrag_err));
goto next;
}
} }
if (ret) { next:
error("defrag failed on %s: %s", argv[i], if (ret)
strerror(defrag_err));
defrag_global_errors++; defrag_global_errors++;
} close_file_or_dir(fd, dirstream);
} }
if (defrag_global_errors) if (defrag_global_errors)
fprintf(stderr, "total %d failures\n", defrag_global_errors); fprintf(stderr, "total %d failures\n", defrag_global_errors);