Fix check for options in "command alias"

Summary:
"command alias" can add invalid options to the command. "command alias start process launch -s" will add an extra argument, "<no-argument>" to the alias, so it runs "process launch -s <no-argument>", which launches the process with args that include "<no-argument>".

This patch changes the text compare of the variable value with "<OptionParser::eNoArgument>" to a compare of variable value_type with OptionParser::eNoArgument. It also moves the previous test inside the if, so it won't add a trailing space if there is no argument.

Reviewers: clayborg

Reviewed By: clayborg

Subscribers: lldb-commits

Differential Revision: http://reviews.llvm.org/D8844

llvm-svn: 234244
This commit is contained in:
Ted Woodward 2015-04-06 21:55:14 +00:00
parent c077b3d0ac
commit e7e8e3cd89
1 changed files with 3 additions and 3 deletions

View File

@ -1457,10 +1457,10 @@ CommandInterpreter::BuildAliasResult (const char *alias_name,
else
{
result_str.Printf (" %s", option.c_str());
if (value_type != OptionParser::eOptionalArgument)
result_str.Printf (" ");
if (value.compare ("<OptionParser::eNoArgument>") != 0)
if (value_type != OptionParser::eNoArgument)
{
if (value_type != OptionParser::eOptionalArgument)
result_str.Printf (" ");
int index = GetOptionArgumentPosition (value.c_str());
if (index == 0)
result_str.Printf ("%s", value.c_str());