diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2020-07-31 21:22:58 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2020-07-31 21:22:58 +0000 | 
| commit | 5ffd83dbcc34f10e07f6d3e968ae6365869615f4 (patch) | |
| tree | 0e9f5cf729dde39f949698fddef45a34e2bc7f44 /contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp | |
| parent | 1799696096df87b52968b8996d00c91e0a5de8d9 (diff) | |
| parent | cfca06d7963fa0909f90483b42a6d7d194d01e08 (diff) | |
Notes
Diffstat (limited to 'contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp')
| -rw-r--r-- | contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp | 65 | 
1 files changed, 39 insertions, 26 deletions
| diff --git a/contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp b/contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp index d666852ee68c..538f7a1ba693 100644 --- a/contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp +++ b/contrib/llvm-project/lldb/source/Interpreter/CommandObject.cpp @@ -1,4 +1,4 @@ -//===-- CommandObject.cpp ---------------------------------------*- C++ -*-===// +//===-- CommandObject.cpp -------------------------------------------------===//  //  // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.  // See https://llvm.org/LICENSE.txt for license information. @@ -18,6 +18,7 @@  #include "lldb/Core/Address.h"  #include "lldb/Interpreter/Options.h"  #include "lldb/Utility/ArchSpec.h" +#include "llvm/ADT/ScopeExit.h"  // These are for the Sourcename completers.  // FIXME: Make a separate file for the completers. @@ -37,14 +38,15 @@ using namespace lldb_private;  // CommandObject -CommandObject::CommandObject(CommandInterpreter &interpreter, llvm::StringRef name, -  llvm::StringRef help, llvm::StringRef syntax, uint32_t flags) -    : m_interpreter(interpreter), m_cmd_name(name), +CommandObject::CommandObject(CommandInterpreter &interpreter, +                             llvm::StringRef name, llvm::StringRef help, +                             llvm::StringRef syntax, uint32_t flags) +    : m_interpreter(interpreter), m_cmd_name(std::string(name)),        m_cmd_help_short(), m_cmd_help_long(), m_cmd_syntax(), m_flags(flags),        m_arguments(), m_deprecated_command_override_callback(nullptr),        m_command_override_callback(nullptr), m_command_override_baton(nullptr) { -  m_cmd_help_short = help; -  m_cmd_syntax = syntax; +  m_cmd_help_short = std::string(help); +  m_cmd_syntax = std::string(syntax);  }  CommandObject::~CommandObject() {} @@ -73,20 +75,28 @@ llvm::StringRef CommandObject::GetSyntax() {        syntax_str.PutCString("-- ");      GetFormattedCommandArguments(syntax_str);    } -  m_cmd_syntax = syntax_str.GetString(); +  m_cmd_syntax = std::string(syntax_str.GetString());    return m_cmd_syntax;  }  llvm::StringRef CommandObject::GetCommandName() const { return m_cmd_name; } -void CommandObject::SetCommandName(llvm::StringRef name) { m_cmd_name = name; } +void CommandObject::SetCommandName(llvm::StringRef name) { +  m_cmd_name = std::string(name); +} -void CommandObject::SetHelp(llvm::StringRef str) { m_cmd_help_short = str; } +void CommandObject::SetHelp(llvm::StringRef str) { +  m_cmd_help_short = std::string(str); +} -void CommandObject::SetHelpLong(llvm::StringRef str) { m_cmd_help_long = str; } +void CommandObject::SetHelpLong(llvm::StringRef str) { +  m_cmd_help_long = std::string(str); +} -void CommandObject::SetSyntax(llvm::StringRef str) { m_cmd_syntax = str; } +void CommandObject::SetSyntax(llvm::StringRef str) { +  m_cmd_syntax = std::string(str); +}  Options *CommandObject::GetOptions() {    // By default commands don't have options unless this virtual function is @@ -258,6 +268,10 @@ void CommandObject::Cleanup() {  }  void CommandObject::HandleCompletion(CompletionRequest &request) { + +  m_exe_ctx = m_interpreter.GetExecutionContext(); +  auto reset_ctx = llvm::make_scope_exit([this]() { Cleanup(); }); +    // Default implementation of WantsCompletion() is !WantsRawCommandString().    // Subclasses who want raw command string but desire, for example, argument    // completion should override WantsCompletion() to return true, instead. @@ -268,7 +282,7 @@ void CommandObject::HandleCompletion(CompletionRequest &request) {    } else {      // Can we do anything generic with the options?      Options *cur_options = GetOptions(); -    CommandReturnObject result; +    CommandReturnObject result(m_interpreter.GetDebugger().GetUseColor());      OptionElementVector opt_element_vector;      if (cur_options != nullptr) { @@ -485,7 +499,7 @@ void CommandObject::GetFormattedCommandArguments(Stream &str,          names.Printf("%s", GetArgumentName(arg_entry[j].arg_type));        } -      std::string name_str = names.GetString(); +      std::string name_str = std::string(names.GetString());        switch (arg_entry[0].arg_repetition) {        case eArgRepeatPlain:          str.Printf("<%s>", name_str.c_str()); @@ -673,7 +687,7 @@ static llvm::StringRef FormatHelpTextCallback() {    sstr.Flush(); -  help_text = sstr.GetString(); +  help_text = std::string(sstr.GetString());    return help_text;  } @@ -691,7 +705,7 @@ static llvm::StringRef LanguageTypeHelpTextCallback() {    sstr.Flush(); -  help_text = sstr.GetString(); +  help_text = std::string(sstr.GetString());    return help_text;  } @@ -809,7 +823,7 @@ static llvm::StringRef ExprPathHelpTextCallback() {  void CommandObject::FormatLongHelpText(Stream &output_strm,                                         llvm::StringRef long_help) {    CommandInterpreter &interpreter = GetCommandInterpreter(); -  std::stringstream lineStream(long_help); +  std::stringstream lineStream{std::string(long_help)};    std::string line;    while (std::getline(lineStream, line)) {      if (line.empty()) { @@ -822,8 +836,8 @@ void CommandObject::FormatLongHelpText(Stream &output_strm,      }      std::string whitespace_prefix = line.substr(0, result);      std::string remainder = line.substr(result); -    interpreter.OutputFormattedHelpText(output_strm, whitespace_prefix.c_str(), -                                        remainder.c_str()); +    interpreter.OutputFormattedHelpText(output_strm, whitespace_prefix, +                                        remainder);    }  } @@ -835,13 +849,11 @@ void CommandObject::GenerateHelpText(CommandReturnObject &result) {  void CommandObject::GenerateHelpText(Stream &output_strm) {    CommandInterpreter &interpreter = GetCommandInterpreter(); +  std::string help_text(GetHelp());    if (WantsRawCommandString()) { -    std::string help_text(GetHelp());      help_text.append("  Expects 'raw' input (see 'help raw-input'.)"); -    interpreter.OutputFormattedHelpText(output_strm, "", "", help_text.c_str(), -                                        1); -  } else -    interpreter.OutputFormattedHelpText(output_strm, "", "", GetHelp(), 1); +  } +  interpreter.OutputFormattedHelpText(output_strm, "", help_text);    output_strm << "\nSyntax: " << GetSyntax() << "\n";    Options *options = GetOptions();    if (options != nullptr) { @@ -1066,7 +1078,7 @@ CommandObject::ArgumentTableEntry CommandObject::g_arguments_data[] = {      { eArgTypePermissionsNumber, "perms-numeric", CommandCompletions::eNoCompletion, { nullptr, false }, "Permissions given as an octal number (e.g. 755)." },      { eArgTypePermissionsString, "perms=string", CommandCompletions::eNoCompletion, { nullptr, false }, "Permissions given as a string value (e.g. rw-r-xr--)." },      { eArgTypePid, "pid", CommandCompletions::eNoCompletion, { nullptr, false }, "The process ID number." }, -    { eArgTypePlugin, "plugin", CommandCompletions::eNoCompletion, { nullptr, false }, "Help text goes here." }, +    { eArgTypePlugin, "plugin", CommandCompletions::eProcessPluginCompletion, { nullptr, false }, "Help text goes here." },      { eArgTypeProcessName, "process-name", CommandCompletions::eNoCompletion, { nullptr, false }, "The name of the process." },      { eArgTypePythonClass, "python-class", CommandCompletions::eNoCompletion, { nullptr, false }, "The name of a Python class." },      { eArgTypePythonFunction, "python-function", CommandCompletions::eNoCompletion, { nullptr, false }, "The name of a Python function." }, @@ -1077,7 +1089,7 @@ CommandObject::ArgumentTableEntry CommandObject::g_arguments_data[] = {      { eArgTypeRunArgs, "run-args", CommandCompletions::eNoCompletion, { nullptr, false }, "Arguments to be passed to the target program when it starts executing." },      { eArgTypeRunMode, "run-mode", CommandCompletions::eNoCompletion, { nullptr, false }, "Help text goes here." },      { eArgTypeScriptedCommandSynchronicity, "script-cmd-synchronicity", CommandCompletions::eNoCompletion, { nullptr, false }, "The synchronicity to use to run scripted commands with regard to LLDB event system." }, -    { eArgTypeScriptLang, "script-language", CommandCompletions::eNoCompletion, { nullptr, false }, "The scripting language to be used for script-based commands.  Currently only Python is valid." }, +    { eArgTypeScriptLang, "script-language", CommandCompletions::eNoCompletion, { nullptr, false }, "The scripting language to be used for script-based commands.  Supported languages are python and lua." },      { eArgTypeSearchWord, "search-word", CommandCompletions::eNoCompletion, { nullptr, false }, "Any word of interest for search purposes." },      { eArgTypeSelector, "selector", CommandCompletions::eNoCompletion, { nullptr, false }, "An Objective-C selector name." },      { eArgTypeSettingIndex, "setting-index", CommandCompletions::eNoCompletion, { nullptr, false }, "An index into a settings variable that is an array (try 'settings list' to see all the possible settings variables and their types)." }, @@ -1105,7 +1117,8 @@ CommandObject::ArgumentTableEntry CommandObject::g_arguments_data[] = {      { eArgTypeWatchpointIDRange, "watchpt-id-list", CommandCompletions::eNoCompletion, { nullptr, false }, "For example, '1-3' or '1 to 3'." },      { eArgTypeWatchType, "watch-type", CommandCompletions::eNoCompletion, { nullptr, false }, "Specify the type for a watchpoint." },      { eArgRawInput, "raw-input", CommandCompletions::eNoCompletion, { nullptr, false }, "Free-form text passed to a command without prior interpretation, allowing spaces without requiring quotes.  To pass arguments and free form text put two dashes ' -- ' between the last argument and any raw input." }, -    { eArgTypeCommand, "command", CommandCompletions::eNoCompletion, { nullptr, false }, "An LLDB Command line command." } +    { eArgTypeCommand, "command", CommandCompletions::eNoCompletion, { nullptr, false }, "An LLDB Command line command." }, +    { eArgTypeColumnNum, "column", CommandCompletions::eNoCompletion, { nullptr, false }, "Column number in a source file." }      // clang-format on  }; | 
