aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llcommandlineparser.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llcommandlineparser.cpp')
-rw-r--r--linden/indra/newview/llcommandlineparser.cpp33
1 files changed, 28 insertions, 5 deletions
diff --git a/linden/indra/newview/llcommandlineparser.cpp b/linden/indra/newview/llcommandlineparser.cpp
index 8123632..45f33dc 100644
--- a/linden/indra/newview/llcommandlineparser.cpp
+++ b/linden/indra/newview/llcommandlineparser.cpp
@@ -291,12 +291,15 @@ bool LLCommandLineParser::parseAndStoreResults(po::command_line_parser& clp)
291 } 291 }
292 catch(LLCLPLastOption&) 292 catch(LLCLPLastOption&)
293 { 293 {
294 // Continue without parsing. 294 // This exception means a token was read after an option
295 std::string msg = "Found tokens past last option. Ignoring."; 295 // that must be the last option was reached (see url and slurl options)
296 llwarns << msg << llendl; 296
297 mErrorMsg = msg; 297 // boost::po will have stored a malformed option.
298 // boost::po will have stored a mal-formed option.
299 // All such options will be removed below. 298 // All such options will be removed below.
299 // The last option read, the last_option option, and its value
300 // are put into the error message.
301 std::string last_option;
302 std::string last_value;
300 for(po::variables_map::iterator i = gVariableMap.begin(); i != gVariableMap.end();) 303 for(po::variables_map::iterator i = gVariableMap.begin(); i != gVariableMap.end();)
301 { 304 {
302 po::variables_map::iterator tempI = i++; 305 po::variables_map::iterator tempI = i++;
@@ -304,7 +307,27 @@ bool LLCommandLineParser::parseAndStoreResults(po::command_line_parser& clp)
304 { 307 {
305 gVariableMap.erase(tempI); 308 gVariableMap.erase(tempI);
306 } 309 }
310 else
311 {
312 last_option = tempI->first;
313 LLCommandLineParser::token_vector_t* tv =
314 boost::any_cast<LLCommandLineParser::token_vector_t>(&(tempI->second.value()));
315 if(!tv->empty())
316 {
317 last_value = (*tv)[tv->size()-1];
318 }
319 }
307 } 320 }
321
322 // Continue without parsing.
323 std::ostringstream msg;
324 msg << "Caught Error: Found options after last option: "
325 << last_option << " "
326 << last_value;
327
328 llwarns << msg.str() << llendl;
329 mErrorMsg = msg.str();
330 return false;
308 } 331 }
309 return true; 332 return true;
310} 333}