mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-11 16:29:42 +00:00
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:
parent
6dd8669a1c
commit
e9db166287
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user