Fix check for options in "command alias"
authorTed Woodward <ted.woodward@codeaurora.org>
Mon, 6 Apr 2015 21:55:14 +0000 (21:55 +0000)
committerTed Woodward <ted.woodward@codeaurora.org>
Mon, 6 Apr 2015 21:55:14 +0000 (21:55 +0000)
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

lldb/source/Interpreter/CommandInterpreter.cpp

index a203d50ce40f58e70890f4a159f9641c0c0cde84..bc55691833d3910401ab0615d620e3f9234d0c43 100644 (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());