From ba6ca031bbe04a226d5a520403622fd84c1be45e Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Tue, 5 Jun 2012 13:53:13 -0600 Subject: [PATCH] fix handling of no-argument options in bootimage.cpp --- src/bootimage.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/bootimage.cpp b/src/bootimage.cpp index 8d5afff495..8d403d0745 100644 --- a/src/bootimage.cpp +++ b/src/bootimage.cpp @@ -1769,8 +1769,10 @@ bool ArgParser::parse(int ac, const char** av) { fprintf(stderr, "expected -parameter\n"); return false; } + bool found = false; for(Arg* arg = first; arg; arg = arg->next) { if(strcmp(arg->name, &av[i][1]) == 0) { + found = true; if (arg->desc == 0) { arg->value = "true"; } else { @@ -1778,7 +1780,7 @@ bool ArgParser::parse(int ac, const char** av) { } } } - if(!state) { + if (not found) { fprintf(stderr, "unrecognized parameter %s\n", av[i]); return false; } @@ -1806,8 +1808,10 @@ void ArgParser::printUsage(const char* exe) { const char* lineEnd = arg->next ? " \\" : ""; if(arg->required) { fprintf(stderr, " -%s\t%s%s\n", arg->name, arg->desc, lineEnd); - } else { + } else if (arg->desc) { fprintf(stderr, " [-%s\t%s]%s\n", arg->name, arg->desc, lineEnd); + } else { + fprintf(stderr, " [-%s]%s\n", arg->name, lineEnd); } } }