From d57a7008f1437076ed57629bb95c42e88d24995a Mon Sep 17 00:00:00 2001 From: Ilya Lavrenov Date: Wed, 9 Oct 2013 17:42:03 +0400 Subject: [PATCH] fixed cmd parser when arg is like -+ --- modules/core/src/cmdparser.cpp | 30 +++++++++++++++++++++++------- 1 file changed, 23 insertions(+), 7 deletions(-) diff --git a/modules/core/src/cmdparser.cpp b/modules/core/src/cmdparser.cpp index 6365baf13b..ecc0d291e9 100644 --- a/modules/core/src/cmdparser.cpp +++ b/modules/core/src/cmdparser.cpp @@ -92,6 +92,22 @@ string del_space(string name) }//namespace +static bool keyIsNumber(const std::string & option, size_t start) +{ + bool isNumber = true; + size_t end = option.find_first_of('=', start); + end = option.npos == end ? option.length() : end; + + for ( ; start < end; ++start) + if (!isdigit(option[start])) + { + isNumber = false; + break; + } + + return isNumber; +} + CommandLineParser::CommandLineParser(int argc, const char* const argv[], const char* keys) { std::string keys_buffer; @@ -144,13 +160,13 @@ CommandLineParser::CommandLineParser(int argc, const char* const argv[], const c if (!argv[i]) break; curName = argv[i]; - if (curName.find('-') == 0 && ((curName[1] < '0') || (curName[1] > '9'))) - { - while (curName.find('-') == 0) - curName.erase(curName.begin(), (curName.begin() + 1)); - } - else - withNoKey = true; + + size_t nondash = curName.find_first_not_of("-"); + if (nondash == 0 || nondash == curName.npos || keyIsNumber(curName, nondash)) + withNoKey = true; + else + curName.erase(0, nondash); + if (curName.find('=') != curName.npos) { hasValueThroughEq = true;