musl: fix getopt optional argument processing
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Tue, 21 Oct 2014 11:03:20 +0000 (11:03 +0000)
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Tue, 21 Oct 2014 11:03:20 +0000 (11:03 +0000)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@43009 3c298f89-4303-0410-b956-a3cf2f4a3e73

toolchain/musl/patches/110-getopt_optional_argument_fix.patch [new file with mode: 0644]

diff --git a/toolchain/musl/patches/110-getopt_optional_argument_fix.patch b/toolchain/musl/patches/110-getopt_optional_argument_fix.patch
new file mode 100644 (file)
index 0000000..7deebdc
--- /dev/null
@@ -0,0 +1,20 @@
+--- a/src/misc/getopt.c
++++ b/src/misc/getopt.c
+@@ -55,7 +55,9 @@ int getopt(int argc, char * const argv[]
+               return '?';
+       }
+       if (optstring[i+1] == ':') {
++              if (optstring[i+2] == ':') optarg = 0;
+               if (optind >= argc) {
++                      if (optstring[i+2] == ':') return c;
+                       if (optstring[0] == ':') return ':';
+                       if (opterr) {
+                               write(2, argv[0], strlen(argv[0]));
+@@ -65,7 +67,6 @@ int getopt(int argc, char * const argv[]
+                       }
+                       return '?';
+               }
+-              if (optstring[i+2] == ':') optarg = 0;
+               if (optstring[i+2] != ':' || optpos) {
+                       optarg = argv[optind++] + optpos;
+                       optpos = 0;