summaryrefslogtreecommitdiff
path: root/util-linux/losetup.c
diff options
context:
space:
mode:
authorDenis Vlasenko2007-09-26 17:54:18 +0000
committerDenis Vlasenko2007-09-26 17:54:18 +0000
commit7ae209c0190c0c6e6b1c95ee9005edf4729e1ce0 (patch)
tree39924a81fa6fa6d7ab2ee7246ce24285078e8ae2 /util-linux/losetup.c
parent137fbe495d3922b71490d01083f04331eb0e6671 (diff)
downloadbusybox-7ae209c0190c0c6e6b1c95ee9005edf4729e1ce0.zip
busybox-7ae209c0190c0c6e6b1c95ee9005edf4729e1ce0.tar.gz
losetup: support -f (Loic Grenie <loic.grenie@gmail.com>)
function old new delta losetup_main 238 278 +40 packed_usage 23021 23027 +6 ------------------------------------------------------------------------------ (add/remove: 0/0 grow/shrink: 2/0 up/down: 46/0) Total: 46 bytes
Diffstat (limited to 'util-linux/losetup.c')
-rw-r--r--util-linux/losetup.c60
1 files changed, 37 insertions, 23 deletions
diff --git a/util-linux/losetup.c b/util-linux/losetup.c
index 9409cdf..57e8569 100644
--- a/util-linux/losetup.c
+++ b/util-linux/losetup.c
@@ -14,54 +14,68 @@
int losetup_main(int argc, char **argv);
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 mutially 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_perror_nomsg_and_die();
+ 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]);
+ return EXIT_SUCCESS;
+ }
+
+ if (argc == 1) {
+ /* -o or no option */
+ s = query_loop(argv[0]);
if (!s)
bb_perror_nomsg_and_die();
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) {
+ printf("%s\n", 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;
}