diff options
author | Wladimir J. van der Laan <laanwj@gmail.com> | 2014-06-12 16:43:47 +0200 |
---|---|---|
committer | Wladimir J. van der Laan <laanwj@gmail.com> | 2014-06-12 16:47:48 +0200 |
commit | 8047fb04ed38f94782221a9724e59a4300460a5e (patch) | |
tree | 93cfa4e4b340d351f6877a968bfc89ebcb095d96 | |
parent | fe1f41728755851dfc000bdb99fce91bc7f24b8d (diff) | |
parent | 71aaff393f06378150612fc618b6c3f84c1d2066 (diff) |
Merge pull request #4193
71aaff3 Remove double-dash parameters from mapArgs (Kosta Zertsekel)
-rw-r--r-- | src/util.cpp | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/src/util.cpp b/src/util.cpp index 3e3dabb678..30590912ff 100644 --- a/src/util.cpp +++ b/src/util.cpp @@ -460,6 +460,7 @@ void ParseParameters(int argc, const char* const argv[]) { mapArgs.clear(); mapMultiArgs.clear(); + for (int i = 1; i < argc; i++) { std::string str(argv[i]); @@ -475,9 +476,15 @@ void ParseParameters(int argc, const char* const argv[]) if (boost::algorithm::starts_with(str, "/")) str = "-" + str.substr(1); #endif + if (str[0] != '-') break; + // Interpret --foo as -foo. + // If both --foo and -foo are set, the last takes effect. + if (str.length() > 1 && str[1] == '-') + str = str.substr(1); + mapArgs[str] = strValue; mapMultiArgs[str].push_back(strValue); } @@ -485,19 +492,8 @@ void ParseParameters(int argc, const char* const argv[]) // New 0.6 features: BOOST_FOREACH(const PAIRTYPE(string,string)& entry, mapArgs) { - string name = entry.first; - - // interpret --foo as -foo (as long as both are not set) - if (name.find("--") == 0) - { - std::string singleDash(name.begin()+1, name.end()); - if (mapArgs.count(singleDash) == 0) - mapArgs[singleDash] = entry.second; - name = singleDash; - } - // interpret -nofoo as -foo=0 (and -nofoo=0 as -foo=1) as long as -foo not set - InterpretNegativeSetting(name, mapArgs); + InterpretNegativeSetting(entry.first, mapArgs); } } |