summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-09-30 20:00:38 -0400
committerRich Felker <dalias@aerifal.cx>2012-09-30 20:00:38 -0400
commit030e52639248ac8417a4934298caa78c21a228d1 (patch)
treeb35e1d3893f3b9db44dd006d1ef944057e9f1906 /src
parente44849f5cf331e655705b18d6c81c616e29d50d0 (diff)
downloadmusl-030e52639248ac8417a4934298caa78c21a228d1.tar.gz
musl-030e52639248ac8417a4934298caa78c21a228d1.tar.bz2
musl-030e52639248ac8417a4934298caa78c21a228d1.tar.xz
musl-030e52639248ac8417a4934298caa78c21a228d1.zip
add getopt reset support
based on proposed patches by Daniel Cegiełka, with minor changes: - use a weak symbol for optreset so it doesn't clash with namespace - also reset optpos (position in multi-option arg like -lR) - also make getopt_long support reset
Diffstat (limited to 'src')
-rw-r--r--src/misc/getopt.c13
-rw-r--r--src/misc/getopt_long.c7
2 files changed, 18 insertions, 2 deletions
diff --git a/src/misc/getopt.c b/src/misc/getopt.c
index abf0e847..35880a09 100644
--- a/src/misc/getopt.c
+++ b/src/misc/getopt.c
@@ -3,10 +3,13 @@
#include <string.h>
#include <limits.h>
#include <stdlib.h>
+#include "libc.h"
char *optarg;
-int optind=1, opterr=1, optopt;
-static int optpos;
+int optind=1, opterr=1, optopt, __optpos, __optreset=0;
+
+#define optpos __optpos
+weak_alias(__optreset, optreset);
int getopt(int argc, char * const argv[], const char *optstring)
{
@@ -15,6 +18,12 @@ int getopt(int argc, char * const argv[], const char *optstring)
int k, l;
char *optchar;
+ if (!optind || __optreset) {
+ __optreset = 0;
+ __optpos = 0;
+ optind = 1;
+ }
+
if (optind >= argc || !argv[optind] || argv[optind][0] != '-' || !argv[optind][1])
return -1;
if (argv[optind][1] == '-' && !argv[optind][2])
diff --git a/src/misc/getopt_long.c b/src/misc/getopt_long.c
index 6d3a4a6e..4ef5a5c7 100644
--- a/src/misc/getopt_long.c
+++ b/src/misc/getopt_long.c
@@ -3,8 +3,15 @@
#include <getopt.h>
#include <stdio.h>
+extern int __optpos, __optreset;
+
static int __getopt_long(int argc, char *const *argv, const char *optstring, const struct option *longopts, int *idx, int longonly)
{
+ if (!optind || __optreset) {
+ __optreset = 0;
+ __optpos = 0;
+ optind = 1;
+ }
if (optind >= argc || !argv[optind] || argv[optind][0] != '-') return -1;
if ((longonly && argv[optind][1]) ||
(argv[optind][1] == '-' && argv[optind][2]))