X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=util-linux%2Flosetup.c;h=e224a4d541cf65774b35734b965e5f83e6d14638;hb=4e5b07b0fed4be34ab3b22666e2a68e7ec2738d8;hp=9409cdff559a35540aae19987316be6028936b8c;hpb=fe7cd642b0b732f5d41403c2f6983ad676b69dd9;p=oweals%2Fbusybox.git diff --git a/util-linux/losetup.c b/util-linux/losetup.c index 9409cdff5..e224a4d54 100644 --- a/util-linux/losetup.c +++ b/util-linux/losetup.c @@ -7,61 +7,73 @@ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details. */ -#include - #include "libbb.h" -int losetup_main(int argc, char **argv); +int losetup_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int losetup_main(int argc, char **argv) { + char dev[] = LOOP_NAME"0"; unsigned opt; char *opt_o; + char *s; unsigned long long offset = 0; - opt = getopt32(argv, "do:", &opt_o); + /* max 2 args, all opts are mutually exclusive */ + opt_complementary = "?2:d--of:o--df:f-do"; + opt = getopt32(argv, "do:f", &opt_o); argc -= optind; argv += optind; - if (opt == 0x3) // -d + -o (illegal) + if (opt == 0x2) // -o + offset = xatoull(opt_o); + + if (opt == 0x4 && argc) // -f does not take any argument bb_show_usage(); if (opt == 0x1) { // -d /* detach takes exactly one argument */ if (argc != 1) bb_show_usage(); - if (!del_loop(argv[0])) - return EXIT_SUCCESS; - bb_perror_nomsg_and_die(); + if (del_loop(argv[0])) + bb_simple_perror_msg_and_die(argv[0]); + return EXIT_SUCCESS; } - if (opt == 0x2) // -o - offset = xatoull(opt_o); - - /* -o or no option */ - if (argc == 2) { + /* -o or no option */ if (set_loop(&argv[0], argv[1], offset) < 0) - bb_perror_nomsg_and_die(); - } else if (argc == 1) { - char *s = query_loop(argv[0]); + bb_simple_perror_msg_and_die(argv[0]); + return EXIT_SUCCESS; + } + + if (argc == 1) { + /* -o or no option */ + s = query_loop(argv[0]); if (!s) - bb_perror_nomsg_and_die(); + bb_simple_perror_msg_and_die(argv[0]); printf("%s: %s\n", argv[0], s); if (ENABLE_FEATURE_CLEAN_UP) free(s); - } else { - char dev[sizeof(LOOP_NAME"0")] = LOOP_NAME"0"; - char c; - for (c = '0'; c <= '9'; ++c) { - char *s; - dev[sizeof(LOOP_NAME"0")-2] = c; - s = query_loop(dev); - if (s) { - printf("%s: %s\n", dev, s); - if (ENABLE_FEATURE_CLEAN_UP) - free(s); + return EXIT_SUCCESS; + } + + /* -o, -f or no option */ + while (1) { + s = query_loop(dev); + if (!s) { + if (opt == 0x4) { + puts(dev); + return EXIT_SUCCESS; } + } else { + if (opt != 0x4) + printf("%s: %s\n", dev, s); + if (ENABLE_FEATURE_CLEAN_UP) + free(s); } + + if (++dev[sizeof(dev) - 2] > '9') + break; } return EXIT_SUCCESS; }