* [PATCH] getopt: Add support for '--' to stop option parsing
@ 2016-07-25 8:32 Sascha Hauer
0 siblings, 0 replies; only message in thread
From: Sascha Hauer @ 2016-07-25 8:32 UTC (permalink / raw)
To: Barebox List
In some cases when commands have optional arguments it is necessary
to explicitly stop option parsing after the last nonpositonal option.
Add support for '--' to accomplish this as done in getopt(3) aswell.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
lib/getopt.c | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/lib/getopt.c b/lib/getopt.c
index fd12a88..847830c 100644
--- a/lib/getopt.c
+++ b/lib/getopt.c
@@ -64,6 +64,11 @@ int getopt(int argc, char *argv[], const char *optstring)
while(1) {
debug("optindex: %d nonopts: %d optind: %d\n", optindex, nonopts, optind);
+ if (optindex == 1 && argv[optind] && !strcmp(argv[optind], "--")) {
+ optind++;
+ return -1;
+ }
+
/* first put nonopts to the end */
while (optind + nonopts < argc && *argv[optind] != '-') {
int i;
--
2.8.1
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2016-07-25 8:33 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-07-25 8:32 [PATCH] getopt: Add support for '--' to stop option parsing Sascha Hauer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox