diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2017-08-08 21:55:02 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2017-08-08 21:55:02 +0200 |
commit | 22542eca18e5807b72ddc78999f5101e33f17a53 (patch) | |
tree | 1271842a37c6215c998674a44bf7f561a0deff52 /util-linux | |
parent | 036585a911a5fe6c2cd77b808dd9150500f37272 (diff) | |
download | busybox-w32-22542eca18e5807b72ddc78999f5101e33f17a53.tar.gz busybox-w32-22542eca18e5807b72ddc78999f5101e33f17a53.tar.bz2 busybox-w32-22542eca18e5807b72ddc78999f5101e33f17a53.zip |
getopt32: remove opt_complementary
function old new delta
vgetopt32 1318 1392 +74
runsvdir_main 703 713 +10
bb_make_directory 423 425 +2
collect_cpu 546 545 -1
opt_chars 3 - -3
opt_complementary 4 - -4
tftpd_main 567 562 -5
ntp_init 476 471 -5
zcip_main 1266 1256 -10
xxd_main 428 418 -10
whois_main 140 130 -10
who_main 463 453 -10
which_main 212 202 -10
wget_main 2535 2525 -10
watchdog_main 291 281 -10
watch_main 222 212 -10
vlock_main 399 389 -10
uuencode_main 332 322 -10
uudecode_main 316 306 -10
unlink_main 45 35 -10
udhcpd_main 1482 1472 -10
udhcpc_main 2762 2752 -10
tune2fs_main 290 280 -10
tunctl_main 366 356 -10
truncate_main 218 208 -10
tr_main 518 508 -10
time_main 1134 1124 -10
tftp_main 286 276 -10
telnetd_main 1873 1863 -10
tcpudpsvd_main 1785 1775 -10
taskset_main 521 511 -10
tar_main 1009 999 -10
tail_main 1644 1634 -10
syslogd_main 1967 1957 -10
switch_root_main 368 358 -10
svlogd_main 1454 1444 -10
sv 1296 1286 -10
stat_main 104 94 -10
start_stop_daemon_main 1028 1018 -10
split_main 542 532 -10
sort_main 796 786 -10
slattach_main 624 614 -10
shuf_main 504 494 -10
setsid_main 96 86 -10
setserial_main 1132 1122 -10
setfont_main 388 378 -10
setconsole_main 78 68 -10
sendmail_main 1209 1199 -10
sed_main 677 667 -10
script_main 1077 1067 -10
run_parts_main 325 315 -10
rtcwake_main 454 444 -10
rm_main 175 165 -10
reformime_main 119 109 -10
readlink_main 123 113 -10
rdate_main 246 236 -10
pwdx_main 189 179 -10
pstree_main 317 307 -10
pscan_main 663 653 -10
popmaildir_main 818 808 -10
pmap_main 80 70 -10
nc_main 1042 1032 -10
mv_main 558 548 -10
mountpoint_main 477 467 -10
mount_main 1264 1254 -10
modprobe_main 768 758 -10
modinfo_main 333 323 -10
mktemp_main 200 190 -10
mkswap_main 324 314 -10
mkfs_vfat_main 1489 1479 -10
microcom_main 715 705 -10
md5_sha1_sum_main 521 511 -10
man_main 867 857 -10
makedevs_main 1052 1042 -10
ls_main 563 553 -10
losetup_main 432 422 -10
loadfont_main 89 79 -10
ln_main 524 514 -10
link_main 75 65 -10
ipcalc_main 544 534 -10
iostat_main 2397 2387 -10
install_main 768 758 -10
id_main 480 470 -10
i2cset_main 1239 1229 -10
i2cget_main 380 370 -10
i2cdump_main 1482 1472 -10
i2cdetect_main 682 672 -10
hwclock_main 406 396 -10
httpd_main 741 731 -10
grep_main 837 827 -10
getty_main 1559 1549 -10
fuser_main 297 287 -10
ftpgetput_main 345 335 -10
ftpd_main 2232 2222 -10
fstrim_main 251 241 -10
fsfreeze_main 77 67 -10
fsck_minix_main 2921 2911 -10
flock_main 314 304 -10
flashcp_main 740 730 -10
flash_eraseall_main 833 823 -10
fdformat_main 532 522 -10
expand_main 680 670 -10
eject_main 335 325 -10
dumpleases_main 630 620 -10
du_main 314 304 -10
dos2unix_main 441 431 -10
diff_main 1350 1340 -10
df_main 1064 1054 -10
date_main 1095 1085 -10
cut_main 961 951 -10
cryptpw_main 228 218 -10
crontab_main 575 565 -10
crond_main 1149 1139 -10
cp_main 370 360 -10
common_traceroute_main 3834 3824 -10
common_ping_main 1767 1757 -10
comm_main 239 229 -10
cmp_main 655 645 -10
chrt_main 379 369 -10
chpst_main 704 694 -10
chpasswd_main 308 298 -10
chown_main 171 161 -10
chmod_main 158 148 -10
cat_main 428 418 -10
bzip2_main 120 110 -10
blkdiscard_main 264 254 -10
base64_main 221 211 -10
arping_main 1665 1655 -10
ar_main 556 546 -10
adjtimex_main 406 396 -10
adduser_main 882 872 -10
addgroup_main 411 401 -10
acpid_main 1198 1188 -10
optstring 11 - -11
opt_string 18 - -18
OPT_STR 25 - -25
ubi_tools_main 1288 1258 -30
ls_options 31 - -31
------------------------------------------------------------------------------
(add/remove: 0/6 grow/shrink: 3/129 up/down: 86/-1383) Total: -1297 bytes
text data bss dec hex filename
915428 485 6876 922789 e14a5 busybox_old
914629 485 6872 921986 e1182 busybox_unstripped
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'util-linux')
-rw-r--r-- | util-linux/acpid.c | 8 | ||||
-rw-r--r-- | util-linux/blkdiscard.c | 3 | ||||
-rw-r--r-- | util-linux/chrt.c | 3 | ||||
-rw-r--r-- | util-linux/eject.c | 5 | ||||
-rw-r--r-- | util-linux/fallocate.c | 3 | ||||
-rw-r--r-- | util-linux/fdformat.c | 3 | ||||
-rw-r--r-- | util-linux/flock.c | 3 | ||||
-rw-r--r-- | util-linux/fsck_minix.c | 3 | ||||
-rw-r--r-- | util-linux/fsfreeze.c | 5 | ||||
-rw-r--r-- | util-linux/fstrim.c | 5 | ||||
-rw-r--r-- | util-linux/hexdump_xxd.c | 5 | ||||
-rw-r--r-- | util-linux/hwclock.c | 7 | ||||
-rw-r--r-- | util-linux/losetup.c | 3 | ||||
-rw-r--r-- | util-linux/mkfs_reiser.c | 3 | ||||
-rw-r--r-- | util-linux/mkfs_vfat.c | 5 | ||||
-rw-r--r-- | util-linux/mkswap.c | 3 | ||||
-rw-r--r-- | util-linux/mount.c | 12 | ||||
-rw-r--r-- | util-linux/mountpoint.c | 3 | ||||
-rw-r--r-- | util-linux/rdate.c | 3 | ||||
-rw-r--r-- | util-linux/rtcwake.c | 6 | ||||
-rw-r--r-- | util-linux/script.c | 6 | ||||
-rw-r--r-- | util-linux/setsid.c | 4 | ||||
-rw-r--r-- | util-linux/switch_root.c | 5 | ||||
-rw-r--r-- | util-linux/taskset.c | 3 | ||||
-rw-r--r-- | util-linux/unshare.c | 21 |
25 files changed, 67 insertions, 63 deletions
diff --git a/util-linux/acpid.c b/util-linux/acpid.c index 3c3811752..4f491fa14 100644 --- a/util-linux/acpid.c +++ b/util-linux/acpid.c | |||
@@ -264,8 +264,12 @@ int acpid_main(int argc UNUSED_PARAM, char **argv) | |||
264 | 264 | ||
265 | INIT_G(); | 265 | INIT_G(); |
266 | 266 | ||
267 | opt_complementary = "df:e--e"; | 267 | opts = getopt32(argv, "^" |
268 | opts = getopt32(argv, "c:de:fl:a:M:" IF_FEATURE_PIDFILE("p:") IF_FEATURE_ACPID_COMPAT("g:m:s:S:v"), | 268 | "c:de:fl:a:M:" |
269 | IF_FEATURE_PIDFILE("p:") | ||
270 | IF_FEATURE_ACPID_COMPAT("g:m:s:S:v") | ||
271 | "\0" | ||
272 | "df:e--e", | ||
269 | &opt_dir, &opt_input, &opt_logfile, &opt_action, &opt_map | 273 | &opt_dir, &opt_input, &opt_logfile, &opt_action, &opt_map |
270 | IF_FEATURE_PIDFILE(, &opt_pidfile) | 274 | IF_FEATURE_PIDFILE(, &opt_pidfile) |
271 | IF_FEATURE_ACPID_COMPAT(, NULL, NULL, NULL, NULL) | 275 | IF_FEATURE_ACPID_COMPAT(, NULL, NULL, NULL, NULL) |
diff --git a/util-linux/blkdiscard.c b/util-linux/blkdiscard.c index 048d39e83..5863f0aab 100644 --- a/util-linux/blkdiscard.c +++ b/util-linux/blkdiscard.c | |||
@@ -53,8 +53,7 @@ int blkdiscard_main(int argc UNUSED_PARAM, char **argv) | |||
53 | OPT_SECURE = (1 << 2), | 53 | OPT_SECURE = (1 << 2), |
54 | }; | 54 | }; |
55 | 55 | ||
56 | opt_complementary = "=1"; | 56 | opts = getopt32(argv, "^" "o:l:s" "\0" "=1", &offset_str, &length_str); |
57 | opts = getopt32(argv, "o:l:s", &offset_str, &length_str); | ||
58 | argv += optind; | 57 | argv += optind; |
59 | 58 | ||
60 | fd = xopen(argv[0], O_RDWR|O_EXCL); | 59 | fd = xopen(argv[0], O_RDWR|O_EXCL); |
diff --git a/util-linux/chrt.c b/util-linux/chrt.c index 52523df02..2712ea3e3 100644 --- a/util-linux/chrt.c +++ b/util-linux/chrt.c | |||
@@ -77,8 +77,7 @@ int chrt_main(int argc UNUSED_PARAM, char **argv) | |||
77 | int policy = SCHED_RR; | 77 | int policy = SCHED_RR; |
78 | 78 | ||
79 | /* only one policy accepted */ | 79 | /* only one policy accepted */ |
80 | opt_complementary = "r--fo:f--ro:o--rf"; | 80 | opt = getopt32(argv, "^+" "mprfo" "\0" "r--fo:f--ro:o--rf"); |
81 | opt = getopt32(argv, "+mprfo"); | ||
82 | if (opt & OPT_m) { /* print min/max and exit */ | 81 | if (opt & OPT_m) { /* print min/max and exit */ |
83 | show_min_max(SCHED_FIFO); | 82 | show_min_max(SCHED_FIFO); |
84 | show_min_max(SCHED_RR); | 83 | show_min_max(SCHED_RR); |
diff --git a/util-linux/eject.c b/util-linux/eject.c index 8095cbef0..6c30facd2 100644 --- a/util-linux/eject.c +++ b/util-linux/eject.c | |||
@@ -124,8 +124,9 @@ int eject_main(int argc UNUSED_PARAM, char **argv) | |||
124 | unsigned flags; | 124 | unsigned flags; |
125 | const char *device; | 125 | const char *device; |
126 | 126 | ||
127 | opt_complementary = "?1:t--T:T--t"; | 127 | flags = getopt32(argv, "^" "tT"IF_FEATURE_EJECT_SCSI("s") |
128 | flags = getopt32(argv, "tT" IF_FEATURE_EJECT_SCSI("s")); | 128 | "\0" "?1:t--T:T--t" |
129 | ); | ||
129 | device = argv[optind] ? argv[optind] : "/dev/cdrom"; | 130 | device = argv[optind] ? argv[optind] : "/dev/cdrom"; |
130 | 131 | ||
131 | /* We used to do "umount <device>" here, but it was buggy | 132 | /* We used to do "umount <device>" here, but it was buggy |
diff --git a/util-linux/fallocate.c b/util-linux/fallocate.c index 70e7e178f..1a02a322f 100644 --- a/util-linux/fallocate.c +++ b/util-linux/fallocate.c | |||
@@ -82,8 +82,7 @@ int fallocate_main(int argc UNUSED_PARAM, char **argv) | |||
82 | int fd; | 82 | int fd; |
83 | 83 | ||
84 | /* exactly one non-option arg */ | 84 | /* exactly one non-option arg */ |
85 | opt_complementary = "=1"; | 85 | opts = getopt32(argv, "^" "l:o:" "\0" "=1", &str_l, &str_o); |
86 | opts = getopt32(argv, "l:o:", &str_l, &str_o); | ||
87 | if (!(opts & 1)) | 86 | if (!(opts & 1)) |
88 | bb_show_usage(); | 87 | bb_show_usage(); |
89 | 88 | ||
diff --git a/util-linux/fdformat.c b/util-linux/fdformat.c index 6faaf1b10..855269c30 100644 --- a/util-linux/fdformat.c +++ b/util-linux/fdformat.c | |||
@@ -66,8 +66,7 @@ int fdformat_main(int argc UNUSED_PARAM, char **argv) | |||
66 | struct floppy_struct param; | 66 | struct floppy_struct param; |
67 | struct format_descr descr; | 67 | struct format_descr descr; |
68 | 68 | ||
69 | opt_complementary = "=1"; /* must have 1 param */ | 69 | verify = !getopt32(argv, "^" "n" "\0" "=1"); |
70 | verify = !getopt32(argv, "n"); | ||
71 | argv += optind; | 70 | argv += optind; |
72 | 71 | ||
73 | xstat(*argv, &st); | 72 | xstat(*argv, &st); |
diff --git a/util-linux/flock.c b/util-linux/flock.c index 0c9158508..dd0bfd430 100644 --- a/util-linux/flock.c +++ b/util-linux/flock.c | |||
@@ -45,9 +45,8 @@ int flock_main(int argc UNUSED_PARAM, char **argv) | |||
45 | "nonblock\0" No_argument "n" | 45 | "nonblock\0" No_argument "n" |
46 | ; | 46 | ; |
47 | #endif | 47 | #endif |
48 | opt_complementary = "-1"; | ||
49 | 48 | ||
50 | opt = getopt32long(argv, "+sxnu", flock_longopts); | 49 | opt = getopt32long(argv, "^+" "sxnu" "\0" "-1", flock_longopts); |
51 | argv += optind; | 50 | argv += optind; |
52 | 51 | ||
53 | if (argv[1]) { | 52 | if (argv[1]) { |
diff --git a/util-linux/fsck_minix.c b/util-linux/fsck_minix.c index 8c2b7d8de..608048983 100644 --- a/util-linux/fsck_minix.c +++ b/util-linux/fsck_minix.c | |||
@@ -1232,8 +1232,7 @@ int fsck_minix_main(int argc UNUSED_PARAM, char **argv) | |||
1232 | 1232 | ||
1233 | INIT_G(); | 1233 | INIT_G(); |
1234 | 1234 | ||
1235 | opt_complementary = "=1:ar"; /* one argument; -a assumes -r */ | 1235 | getopt32(argv, "^" OPTION_STR "\0" "=1:ar" /* one arg; -a assumes -r */); |
1236 | getopt32(argv, OPTION_STR); | ||
1237 | argv += optind; | 1236 | argv += optind; |
1238 | device_name = argv[0]; | 1237 | device_name = argv[0]; |
1239 | 1238 | ||
diff --git a/util-linux/fsfreeze.c b/util-linux/fsfreeze.c index af715da5e..2e2257337 100644 --- a/util-linux/fsfreeze.c +++ b/util-linux/fsfreeze.c | |||
@@ -39,8 +39,9 @@ int fsfreeze_main(int argc UNUSED_PARAM, char **argv) | |||
39 | /* exactly one non-option arg: the mountpoint */ | 39 | /* exactly one non-option arg: the mountpoint */ |
40 | /* one of opts is required */ | 40 | /* one of opts is required */ |
41 | /* opts are mutually exclusive */ | 41 | /* opts are mutually exclusive */ |
42 | opt_complementary = "=1:""\xff:\xfe:""\xff--\xfe:\xfe--\xff"; | 42 | opts = getopt32long(argv, "^" |
43 | opts = getopt32long(argv, "", | 43 | "" /* no opts */ |
44 | "\0" "=1:""\xff:\xfe:""\xff--\xfe:\xfe--\xff", | ||
44 | "freeze\0" No_argument "\xff" | 45 | "freeze\0" No_argument "\xff" |
45 | "unfreeze\0" No_argument "\xfe" | 46 | "unfreeze\0" No_argument "\xfe" |
46 | ); | 47 | ); |
diff --git a/util-linux/fstrim.c b/util-linux/fstrim.c index 8f0a0538f..4acfa567a 100644 --- a/util-linux/fstrim.c +++ b/util-linux/fstrim.c | |||
@@ -71,8 +71,9 @@ int fstrim_main(int argc UNUSED_PARAM, char **argv) | |||
71 | ; | 71 | ; |
72 | #endif | 72 | #endif |
73 | 73 | ||
74 | opt_complementary = "=1"; /* exactly one non-option arg: the mountpoint */ | 74 | opts = getopt32long(argv, "^" "o:l:m:v" "\0" "=1", fstrim_longopts, |
75 | opts = getopt32long(argv, "o:l:m:v", fstrim_longopts, &arg_o, &arg_l, &arg_m); | 75 | &arg_o, &arg_l, &arg_m |
76 | ); | ||
76 | 77 | ||
77 | memset(&range, 0, sizeof(range)); | 78 | memset(&range, 0, sizeof(range)); |
78 | range.len = ULLONG_MAX; | 79 | range.len = ULLONG_MAX; |
diff --git a/util-linux/hexdump_xxd.c b/util-linux/hexdump_xxd.c index 37e58f2d0..6cf6d0297 100644 --- a/util-linux/hexdump_xxd.c +++ b/util-linux/hexdump_xxd.c | |||
@@ -73,8 +73,9 @@ int xxd_main(int argc UNUSED_PARAM, char **argv) | |||
73 | #define OPT_s (1 << 1) | 73 | #define OPT_s (1 << 1) |
74 | #define OPT_a (1 << 2) | 74 | #define OPT_a (1 << 2) |
75 | #define OPT_p (1 << 3) | 75 | #define OPT_p (1 << 3) |
76 | opt_complementary = "?1"; /* 1 argument max */ | 76 | opt = getopt32(argv, "^" "l:s:apg:+c:+" "\0" "?1" /* 1 argument max */, |
77 | opt = getopt32(argv, "l:s:apg:+c:+", &opt_l, &opt_s, &bytes, &cols); | 77 | &opt_l, &opt_s, &bytes, &cols |
78 | ); | ||
78 | argv += optind; | 79 | argv += optind; |
79 | 80 | ||
80 | dumper->dump_vflag = ALL; | 81 | dumper->dump_vflag = ALL; |
diff --git a/util-linux/hwclock.c b/util-linux/hwclock.c index 50f83d8c4..29f51021e 100644 --- a/util-linux/hwclock.c +++ b/util-linux/hwclock.c | |||
@@ -343,8 +343,11 @@ int hwclock_main(int argc UNUSED_PARAM, char **argv) | |||
343 | /* Initialize "timezone" (libc global variable) */ | 343 | /* Initialize "timezone" (libc global variable) */ |
344 | tzset(); | 344 | tzset(); |
345 | 345 | ||
346 | opt_complementary = "r--wst:w--rst:s--wrt:t--rsw:l--u:u--l"; | 346 | opt = getopt32long(argv, |
347 | opt = getopt32long(argv, "lurswtf:", hwclock_longopts, &rtcname); | 347 | "^lurswtf:" "\0" "r--wst:w--rst:s--wrt:t--rsw:l--u:u--l", |
348 | hwclock_longopts, | ||
349 | &rtcname | ||
350 | ); | ||
348 | 351 | ||
349 | /* If -u or -l wasn't given check if we are using utc */ | 352 | /* If -u or -l wasn't given check if we are using utc */ |
350 | if (opt & (HWCLOCK_OPT_UTC | HWCLOCK_OPT_LOCALTIME)) | 353 | if (opt & (HWCLOCK_OPT_UTC | HWCLOCK_OPT_LOCALTIME)) |
diff --git a/util-linux/losetup.c b/util-linux/losetup.c index 2f7dc10f5..6b171d710 100644 --- a/util-linux/losetup.c +++ b/util-linux/losetup.c | |||
@@ -57,8 +57,7 @@ int losetup_main(int argc UNUSED_PARAM, char **argv) | |||
57 | OPT_r = (1 << 4), /* must be last */ | 57 | OPT_r = (1 << 4), /* must be last */ |
58 | }; | 58 | }; |
59 | 59 | ||
60 | opt_complementary = "?2:d--ofar:a--ofr"; | 60 | opt = getopt32(argv, "^" "do:far" "\0" "?2:d--ofar:a--ofr", &opt_o); |
61 | opt = getopt32(argv, "do:far", &opt_o); | ||
62 | argv += optind; | 61 | argv += optind; |
63 | 62 | ||
64 | /* LOOPDEV */ | 63 | /* LOOPDEV */ |
diff --git a/util-linux/mkfs_reiser.c b/util-linux/mkfs_reiser.c index c7d99b018..390aef86c 100644 --- a/util-linux/mkfs_reiser.c +++ b/util-linux/mkfs_reiser.c | |||
@@ -180,8 +180,7 @@ int mkfs_reiser_main(int argc UNUSED_PARAM, char **argv) | |||
180 | 180 | ||
181 | // using global "option_mask32" instead of local "opts": | 181 | // using global "option_mask32" instead of local "opts": |
182 | // we are register starved here | 182 | // we are register starved here |
183 | opt_complementary = "-1"; | 183 | /*opts =*/ getopt32(argv, "^" "b:+j:s:o:t:B:h:u:l:fqd" "\0" "-1", |
184 | /*opts =*/ getopt32(argv, "b:+j:s:o:t:B:h:u:l:fqd", | ||
185 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, &label); | 184 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, &label); |
186 | argv += optind; // argv[0] -- device | 185 | argv += optind; // argv[0] -- device |
187 | 186 | ||
diff --git a/util-linux/mkfs_vfat.c b/util-linux/mkfs_vfat.c index f9768ed56..426854b1e 100644 --- a/util-linux/mkfs_vfat.c +++ b/util-linux/mkfs_vfat.c | |||
@@ -269,8 +269,9 @@ int mkfs_vfat_main(int argc UNUSED_PARAM, char **argv) | |||
269 | OPT_v = 1 << 16, // verbose | 269 | OPT_v = 1 << 16, // verbose |
270 | }; | 270 | }; |
271 | 271 | ||
272 | opt_complementary = "-1";//:b+:f+:F+:h+:r+:R+:s+:S+:vv:c--l:l--c"; | 272 | opts = getopt32(argv, "^" |
273 | opts = getopt32(argv, "Ab:cCf:F:h:Ii:l:m:n:r:R:s:S:v", | 273 | "Ab:cCf:F:h:Ii:l:m:n:r:R:s:S:v" |
274 | "\0" "-1", //:b+:f+:F+:h+:r+:R+:s+:S+:vv:c--l:l--c | ||
274 | NULL, NULL, NULL, NULL, NULL, | 275 | NULL, NULL, NULL, NULL, NULL, |
275 | NULL, NULL, &volume_label, NULL, NULL, NULL, NULL); | 276 | NULL, NULL, &volume_label, NULL, NULL, NULL, NULL); |
276 | argv += optind; | 277 | argv += optind; |
diff --git a/util-linux/mkswap.c b/util-linux/mkswap.c index e44e13c0d..71449882d 100644 --- a/util-linux/mkswap.c +++ b/util-linux/mkswap.c | |||
@@ -119,9 +119,8 @@ int mkswap_main(int argc UNUSED_PARAM, char **argv) | |||
119 | 119 | ||
120 | INIT_G(); | 120 | INIT_G(); |
121 | 121 | ||
122 | opt_complementary = "-1"; /* at least one param */ | ||
123 | /* TODO: -p PAGESZ, -U UUID */ | 122 | /* TODO: -p PAGESZ, -U UUID */ |
124 | getopt32(argv, "L:", &label); | 123 | getopt32(argv, "^" "L:" "\0" "-1"/*at least one arg*/, &label); |
125 | argv += optind; | 124 | argv += optind; |
126 | 125 | ||
127 | fd = xopen(argv[0], O_WRONLY); | 126 | fd = xopen(argv[0], O_WRONLY); |
diff --git a/util-linux/mount.c b/util-linux/mount.c index 4d5c2243a..b8dd8a925 100644 --- a/util-linux/mount.c +++ b/util-linux/mount.c | |||
@@ -2205,10 +2205,14 @@ int mount_main(int argc UNUSED_PARAM, char **argv) | |||
2205 | 2205 | ||
2206 | // Parse remaining options | 2206 | // Parse remaining options |
2207 | // Max 2 params; -o is a list, -v is a counter | 2207 | // Max 2 params; -o is a list, -v is a counter |
2208 | opt_complementary = "?2" IF_FEATURE_MOUNT_VERBOSE("vv"); | 2208 | opt = getopt32(argv, "^" |
2209 | opt = getopt32(argv, OPTION_STR, &lst_o, &fstype, &O_optmatch | 2209 | OPTION_STR |
2210 | IF_FEATURE_MOUNT_OTHERTAB(, &fstabname) | 2210 | "\0" "?2"IF_FEATURE_MOUNT_VERBOSE("vv"), |
2211 | IF_FEATURE_MOUNT_VERBOSE(, &verbose)); | 2211 | &lst_o, &fstype, &O_optmatch |
2212 | IF_FEATURE_MOUNT_OTHERTAB(, &fstabname) | ||
2213 | IF_FEATURE_MOUNT_VERBOSE(, &verbose) | ||
2214 | ); | ||
2215 | |||
2212 | while (lst_o) append_mount_options(&cmdopts, llist_pop(&lst_o)); // -o | 2216 | while (lst_o) append_mount_options(&cmdopts, llist_pop(&lst_o)); // -o |
2213 | if (opt & OPT_r) append_mount_options(&cmdopts, "ro"); // -r | 2217 | if (opt & OPT_r) append_mount_options(&cmdopts, "ro"); // -r |
2214 | if (opt & OPT_w) append_mount_options(&cmdopts, "rw"); // -w | 2218 | if (opt & OPT_w) append_mount_options(&cmdopts, "rw"); // -w |
diff --git a/util-linux/mountpoint.c b/util-linux/mountpoint.c index 50772533f..6b21a5fb3 100644 --- a/util-linux/mountpoint.c +++ b/util-linux/mountpoint.c | |||
@@ -43,8 +43,7 @@ int mountpoint_main(int argc UNUSED_PARAM, char **argv) | |||
43 | char *arg; | 43 | char *arg; |
44 | int rc, opt; | 44 | int rc, opt; |
45 | 45 | ||
46 | opt_complementary = "=1"; /* must have one argument */ | 46 | opt = getopt32(argv, "^" "qdxn" "\0" "=1"); |
47 | opt = getopt32(argv, "qdxn"); | ||
48 | #define OPT_q (1) | 47 | #define OPT_q (1) |
49 | #define OPT_d (2) | 48 | #define OPT_d (2) |
50 | #define OPT_x (4) | 49 | #define OPT_x (4) |
diff --git a/util-linux/rdate.c b/util-linux/rdate.c index 14ce591e9..f27294e25 100644 --- a/util-linux/rdate.c +++ b/util-linux/rdate.c | |||
@@ -81,8 +81,7 @@ int rdate_main(int argc UNUSED_PARAM, char **argv) | |||
81 | time_t remote_time; | 81 | time_t remote_time; |
82 | unsigned flags; | 82 | unsigned flags; |
83 | 83 | ||
84 | opt_complementary = "-1"; | 84 | flags = getopt32(argv, "^" "sp" "\0" "-1"); |
85 | flags = getopt32(argv, "sp"); | ||
86 | 85 | ||
87 | remote_time = askremotedate(argv[optind]); | 86 | remote_time = askremotedate(argv[optind]); |
88 | 87 | ||
diff --git a/util-linux/rtcwake.c b/util-linux/rtcwake.c index 2a3d61f21..8ffa4f3a6 100644 --- a/util-linux/rtcwake.c +++ b/util-linux/rtcwake.c | |||
@@ -155,9 +155,9 @@ int rtcwake_main(int argc UNUSED_PARAM, char **argv) | |||
155 | "time\0" Required_argument "t" | 155 | "time\0" Required_argument "t" |
156 | ; | 156 | ; |
157 | #endif | 157 | #endif |
158 | /* Must have -s or -t, exclusive */ | 158 | opt = getopt32long(argv, |
159 | opt_complementary = "s:t:s--t:t--s"; | 159 | /* Must have -s or -t, exclusive */ |
160 | opt = getopt32long(argv, "alud:m:s:t:", rtcwake_longopts, | 160 | "^alud:m:s:t:" "\0" "s:t:s--t:t--s", rtcwake_longopts, |
161 | &rtcname, &suspend, &opt_seconds, &opt_time); | 161 | &rtcname, &suspend, &opt_seconds, &opt_time); |
162 | 162 | ||
163 | /* this is the default | 163 | /* this is the default |
diff --git a/util-linux/script.c b/util-linux/script.c index 8174c65bf..aac77c3ba 100644 --- a/util-linux/script.c +++ b/util-linux/script.c | |||
@@ -80,8 +80,10 @@ int script_main(int argc UNUSED_PARAM, char **argv) | |||
80 | ; | 80 | ; |
81 | #endif | 81 | #endif |
82 | 82 | ||
83 | opt_complementary = "?1"; /* max one arg */ | 83 | opt = getopt32long(argv, "^" "ac:fqt::" "\0" "?1"/* max one arg */, |
84 | opt = getopt32long(argv, "ac:fqt::", script_longopts, &shell_arg, &str_t); | 84 | script_longopts, |
85 | &shell_arg, &str_t | ||
86 | ); | ||
85 | //argc -= optind; | 87 | //argc -= optind; |
86 | argv += optind; | 88 | argv += optind; |
87 | if (argv[0]) { | 89 | if (argv[0]) { |
diff --git a/util-linux/setsid.c b/util-linux/setsid.c index 60cab2fcf..8385a9115 100644 --- a/util-linux/setsid.c +++ b/util-linux/setsid.c | |||
@@ -37,8 +37,8 @@ int setsid_main(int argc UNUSED_PARAM, char **argv) | |||
37 | { | 37 | { |
38 | unsigned opt; | 38 | unsigned opt; |
39 | 39 | ||
40 | opt_complementary = "-1"; /* at least one arg */ | 40 | /* +: stop on first non-opt */ |
41 | opt = getopt32(argv, "+c"); /* +: stop on first non-opt */ | 41 | opt = getopt32(argv, "^+" "c" "\0" "-1"/* at least one arg */); |
42 | argv += optind; | 42 | argv += optind; |
43 | 43 | ||
44 | /* setsid() is allowed only when we are not a process group leader. | 44 | /* setsid() is allowed only when we are not a process group leader. |
diff --git a/util-linux/switch_root.c b/util-linux/switch_root.c index 32708934e..fb6057a02 100644 --- a/util-linux/switch_root.c +++ b/util-linux/switch_root.c | |||
@@ -97,9 +97,8 @@ int switch_root_main(int argc UNUSED_PARAM, char **argv) | |||
97 | struct statfs stfs; | 97 | struct statfs stfs; |
98 | dev_t rootdev; | 98 | dev_t rootdev; |
99 | 99 | ||
100 | // Parse args (-c console) | 100 | // Parse args (-c console). '+': stop at first non-option |
101 | opt_complementary = "-2"; // minimum 2 params | 101 | getopt32(argv, "^+" "c:" "\0" "-2" /* minimum 2 args */, &console); |
102 | getopt32(argv, "+c:", &console); // '+': stop at first non-option | ||
103 | argv += optind; | 102 | argv += optind; |
104 | newroot = *argv++; | 103 | newroot = *argv++; |
105 | 104 | ||
diff --git a/util-linux/taskset.c b/util-linux/taskset.c index 89dea176e..401a1bcb7 100644 --- a/util-linux/taskset.c +++ b/util-linux/taskset.c | |||
@@ -123,8 +123,7 @@ int taskset_main(int argc UNUSED_PARAM, char **argv) | |||
123 | * Indeed, util-linux-2.13-pre7 uses: | 123 | * Indeed, util-linux-2.13-pre7 uses: |
124 | * getopt_long(argc, argv, "+pchV", ...), not "...p:..." */ | 124 | * getopt_long(argc, argv, "+pchV", ...), not "...p:..." */ |
125 | 125 | ||
126 | opt_complementary = "-1"; /* at least 1 arg */ | 126 | opt_p = getopt32(argv, "^+" "p" "\0" "-1" /* at least 1 arg */); |
127 | opt_p = getopt32(argv, "+p"); | ||
128 | argv += optind; | 127 | argv += optind; |
129 | 128 | ||
130 | aff = *argv++; | 129 | aff = *argv++; |
diff --git a/util-linux/unshare.c b/util-linux/unshare.c index df377478f..6a3da9f91 100644 --- a/util-linux/unshare.c +++ b/util-linux/unshare.c | |||
@@ -137,7 +137,7 @@ static const struct namespace_descr ns_list[] = { | |||
137 | * we are forced to use "fake" letters for them. | 137 | * we are forced to use "fake" letters for them. |
138 | * '+': stop at first non-option. | 138 | * '+': stop at first non-option. |
139 | */ | 139 | */ |
140 | static const char opt_str[] ALIGN1 = "+muinpU""fr""\xfd::""\xfe:""\xff:"; | 140 | #define OPT_STR "+muinpU""fr""\xfd::""\xfe:""\xff:" |
141 | static const char unshare_longopts[] ALIGN1 = | 141 | static const char unshare_longopts[] ALIGN1 = |
142 | "mount\0" Optional_argument "\xf0" | 142 | "mount\0" Optional_argument "\xf0" |
143 | "uts\0" Optional_argument "\xf1" | 143 | "uts\0" Optional_argument "\xf1" |
@@ -210,7 +210,7 @@ int unshare_main(int argc UNUSED_PARAM, char **argv) | |||
210 | prop_str = PRIVATE_STR; | 210 | prop_str = PRIVATE_STR; |
211 | setgrp_str = NULL; | 211 | setgrp_str = NULL; |
212 | 212 | ||
213 | opt_complementary = | 213 | opts = getopt32long(argv, "^" OPT_STR "\0" |
214 | "\xf0""m" /* long opts (via their "fake chars") imply short opts */ | 214 | "\xf0""m" /* long opts (via their "fake chars") imply short opts */ |
215 | ":\xf1""u" | 215 | ":\xf1""u" |
216 | ":\xf2""i" | 216 | ":\xf2""i" |
@@ -219,15 +219,14 @@ int unshare_main(int argc UNUSED_PARAM, char **argv) | |||
219 | ":\xf5""U" | 219 | ":\xf5""U" |
220 | ":ru" /* --map-root-user or -r implies -u */ | 220 | ":ru" /* --map-root-user or -r implies -u */ |
221 | ":\xfd""m" /* --mount-proc implies -m */ | 221 | ":\xfd""m" /* --mount-proc implies -m */ |
222 | ; | 222 | , unshare_longopts, |
223 | opts = getopt32long(argv, opt_str, unshare_longopts, | 223 | &proc_mnt_target, &prop_str, &setgrp_str, |
224 | &proc_mnt_target, &prop_str, &setgrp_str, | 224 | &ns_ctx_list[NS_MNT_POS].path, |
225 | &ns_ctx_list[NS_MNT_POS].path, | 225 | &ns_ctx_list[NS_UTS_POS].path, |
226 | &ns_ctx_list[NS_UTS_POS].path, | 226 | &ns_ctx_list[NS_IPC_POS].path, |
227 | &ns_ctx_list[NS_IPC_POS].path, | 227 | &ns_ctx_list[NS_NET_POS].path, |
228 | &ns_ctx_list[NS_NET_POS].path, | 228 | &ns_ctx_list[NS_PID_POS].path, |
229 | &ns_ctx_list[NS_PID_POS].path, | 229 | &ns_ctx_list[NS_USR_POS].path |
230 | &ns_ctx_list[NS_USR_POS].path | ||
231 | ); | 230 | ); |
232 | argv += optind; | 231 | argv += optind; |
233 | //bb_error_msg("opts:0x%x", opts); | 232 | //bb_error_msg("opts:0x%x", opts); |