aboutsummaryrefslogtreecommitdiff
path: root/util-linux
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2017-08-08 21:55:02 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2017-08-08 21:55:02 +0200
commit22542eca18e5807b72ddc78999f5101e33f17a53 (patch)
tree1271842a37c6215c998674a44bf7f561a0deff52 /util-linux
parent036585a911a5fe6c2cd77b808dd9150500f37272 (diff)
downloadbusybox-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.c8
-rw-r--r--util-linux/blkdiscard.c3
-rw-r--r--util-linux/chrt.c3
-rw-r--r--util-linux/eject.c5
-rw-r--r--util-linux/fallocate.c3
-rw-r--r--util-linux/fdformat.c3
-rw-r--r--util-linux/flock.c3
-rw-r--r--util-linux/fsck_minix.c3
-rw-r--r--util-linux/fsfreeze.c5
-rw-r--r--util-linux/fstrim.c5
-rw-r--r--util-linux/hexdump_xxd.c5
-rw-r--r--util-linux/hwclock.c7
-rw-r--r--util-linux/losetup.c3
-rw-r--r--util-linux/mkfs_reiser.c3
-rw-r--r--util-linux/mkfs_vfat.c5
-rw-r--r--util-linux/mkswap.c3
-rw-r--r--util-linux/mount.c12
-rw-r--r--util-linux/mountpoint.c3
-rw-r--r--util-linux/rdate.c3
-rw-r--r--util-linux/rtcwake.c6
-rw-r--r--util-linux/script.c6
-rw-r--r--util-linux/setsid.c4
-rw-r--r--util-linux/switch_root.c5
-rw-r--r--util-linux/taskset.c3
-rw-r--r--util-linux/unshare.c21
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 */
140static const char opt_str[] ALIGN1 = "+muinpU""fr""\xfd::""\xfe:""\xff:"; 140#define OPT_STR "+muinpU""fr""\xfd::""\xfe:""\xff:"
141static const char unshare_longopts[] ALIGN1 = 141static 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);