diff options
author | Peter S. Mazinger <ps.m@gmx.net> | 2006-03-03 21:21:33 +0000 |
---|---|---|
committer | Peter S. Mazinger <ps.m@gmx.net> | 2006-03-03 21:21:33 +0000 |
commit | 82ff19e279cc8fae158947314e8c07034dd5b1e5 (patch) | |
tree | e00eaaa60d395aba74b579c7c87cf07a02d665fa /libc/unistd/getopt_long-simple.c | |
parent | 2fb90be2fc519af1f18bb94f1b0ee54d49bd3ab8 (diff) |
Rename getopt_long-susv3 to -simple
Diffstat (limited to 'libc/unistd/getopt_long-simple.c')
-rw-r--r-- | libc/unistd/getopt_long-simple.c | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/libc/unistd/getopt_long-simple.c b/libc/unistd/getopt_long-simple.c new file mode 100644 index 000000000..2dae341a3 --- /dev/null +++ b/libc/unistd/getopt_long-simple.c @@ -0,0 +1,58 @@ +/* + * Copyright (C) 2006 Rich Felker <dalias@aerifal.cx> + * + * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. + */ + +#include <stddef.h> +#include <getopt.h> +#include <stdio.h> + +libc_hidden_proto(getopt) + +static int __getopt_long(int argc, char *const *argv, const char *optstring, const struct option *longopts, int *idx, int longonly) +{ + if (optind >= argc || !argv[optind] || argv[optind][0] != '-') return -1; + if ((longonly && argv[optind][1]) || + (argv[optind][1] == '-' && argv[optind][2])) + { + int i; + for (i=0; longopts[i].name; i++) { + const char *name = longopts[i].name; + char *opt = argv[optind]+2; + while (*name && *name++ == *opt++); + if (*name || (*opt && *opt != '=')) continue; + if (*opt == '=') { + if (!longopts[i].has_arg) continue; + optarg = opt+1; + } else { + if (longopts[i].has_arg == required_argument) { + if (!(optarg = argv[++optind])) + return ':'; + } else optarg = NULL; + } + optind++; + if (idx) *idx = i; + if (longopts[i].flag) { + *longopts[i].flag = longopts[i].val; + return 0; + } + return longopts[i].val; + } + if (argv[optind][1] == '-') { + optind++; + return '?'; + } + } + return getopt(argc, argv, optstring); +} + +int getopt_long(int argc, char *const *argv, const char *optstring, const struct option *longopts, int *idx) +{ + return __getopt_long(argc, argv, optstring, longopts, idx, 0); +} + +int getopt_long_only(int argc, char *const *argv, const char *optstring, const struct option *longopts, int *idx) +{ + return __getopt_long(argc, argv, optstring, longopts, idx, 1); +} |