llvmbot wrote:

<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-lldb

Author: None (jimingham)

<details>
<summary>Changes</summary>

Most commands were adding argument completion handling by themselves, resulting 
in a lot of unnecessary boilerplate.  In many cases, this could be done 
generically given the argument definition and the entries in the 
g_argument_table.

I'm going to address this in a couple passes.  In this first pass, I added 
handling of commands that have only one argument list, with one argument type, 
either single or repeated, and changed all the commands that are of this sort 
(and don't have other bits of business in their completers.)

I also added some missing connections between arg types and completions to the 
table, and added a RemoteFilename and RemotePath to use in places where we were 
using the Remote completers.  Those arguments used to say they were "files" but 
they were in fact remote files.

I also added a module arg type to use where we were using the module completer. 
 In that case, we should call the argument module.

---

Patch is 39.50 KiB, truncated to 20.00 KiB below, full version: 
https://github.com/llvm/llvm-project/pull/82085.diff


19 Files Affected:

- (modified) lldb/include/lldb/Interpreter/CommandObject.h (+8-1) 
- (modified) lldb/include/lldb/Interpreter/CommandOptionArgumentTable.h (+12-9) 
- (modified) lldb/include/lldb/lldb-enumerations.h (+3) 
- (modified) lldb/source/Commands/CommandObjectCommands.cpp (-14) 
- (modified) lldb/source/Commands/CommandObjectDWIMPrint.cpp (-6) 
- (modified) lldb/source/Commands/CommandObjectDWIMPrint.h (-4) 
- (modified) lldb/source/Commands/CommandObjectFrame.cpp (-19) 
- (modified) lldb/source/Commands/CommandObjectPlatform.cpp (+17-57) 
- (modified) lldb/source/Commands/CommandObjectPlugin.cpp (-7) 
- (modified) lldb/source/Commands/CommandObjectProcess.cpp (+1-18) 
- (modified) lldb/source/Commands/CommandObjectRegister.cpp (+2-5) 
- (modified) lldb/source/Commands/CommandObjectSession.cpp (-7) 
- (modified) lldb/source/Commands/CommandObjectSettings.cpp (-8) 
- (modified) lldb/source/Commands/CommandObjectTarget.cpp (+3-26) 
- (modified) lldb/source/Commands/CommandObjectThread.cpp (+1-12) 
- (modified) lldb/source/Commands/CommandObjectType.cpp (-32) 
- (modified) lldb/source/Commands/CommandObjectWatchpoint.cpp (-10) 
- (modified) lldb/source/Interpreter/CommandObject.cpp (+36) 
- (modified) lldb/test/API/commands/help/TestHelp.py (+1-1) 


``````````diff
diff --git a/lldb/include/lldb/Interpreter/CommandObject.h 
b/lldb/include/lldb/Interpreter/CommandObject.h
index 7b427de0264f75..537acb450296b5 100644
--- a/lldb/include/lldb/Interpreter/CommandObject.h
+++ b/lldb/include/lldb/Interpreter/CommandObject.h
@@ -239,6 +239,13 @@ class CommandObject : public 
std::enable_shared_from_this<CommandObject> {
   ///    The completion request that needs to be answered.
   virtual void HandleCompletion(CompletionRequest &request);
 
+  /// The default version handles argument definitions that have only one
+  /// argument type, and use one of the argument types that have an entry in
+  /// the CommonCompletions.  Override this if you have a more complex 
+  /// argument setup.  
+  /// FIXME: we should be able to extend this to more complex argument 
+  /// definitions provided we have completers for all the argument types.
+  ///  
   /// The input array contains a parsed version of the line.
   ///
   /// We've constructed the map of options and their arguments as well if that
@@ -248,7 +255,7 @@ class CommandObject : public 
std::enable_shared_from_this<CommandObject> {
   ///    The completion request that needs to be answered.
   virtual void
   HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) {}
+                           OptionElementVector &opt_element_vector);
 
   bool HelpTextContainsWord(llvm::StringRef search_word,
                             bool search_short_help = true,
diff --git a/lldb/include/lldb/Interpreter/CommandOptionArgumentTable.h 
b/lldb/include/lldb/Interpreter/CommandOptionArgumentTable.h
index d0cf54c31ca73f..ab5eff699b4cf0 100644
--- a/lldb/include/lldb/Interpreter/CommandOptionArgumentTable.h
+++ b/lldb/include/lldb/Interpreter/CommandOptionArgumentTable.h
@@ -243,7 +243,7 @@ static constexpr CommandObject::ArgumentTableEntry 
g_argument_table[] = {
     { lldb::eArgTypeLogCategory, "log-category", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of a 
category within a log channel, e.g. all (try \"log list\" to see a list of all 
channels and their categories." },
     { lldb::eArgTypeLogChannel, "log-channel", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of a log 
channel, e.g. process.gdb-remote (try \"log list\" to see a list of all 
channels and their categories)." },
     { lldb::eArgTypeMethod, "method", lldb::CompletionType::eNoCompletion, {}, 
{ nullptr, false }, "A C++ method name." },
-    { lldb::eArgTypeName, "name", lldb::eTypeCategoryNameCompletion, {}, { 
nullptr, false }, "Help text goes here." },
+    { lldb::eArgTypeName, "name", lldb::eTypeCategoryNameCompletion, {}, { 
nullptr, false }, "The name of a type category." },
     { lldb::eArgTypeNewPathPrefix, "new-path-prefix", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "Help text goes 
here." },
     { lldb::eArgTypeNumLines, "num-lines", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The number of 
lines to use." },
     { lldb::eArgTypeNumberPerLine, "number-per-line", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The number of 
items per line to display." },
@@ -262,7 +262,7 @@ static constexpr CommandObject::ArgumentTableEntry 
g_argument_table[] = {
     { lldb::eArgTypeQueueName, "queue-name", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of the 
thread queue." },
     { lldb::eArgTypeRegisterName, "register-name", 
lldb::CompletionType::eNoCompletion, {}, { RegisterNameHelpTextCallback, true 
}, nullptr },
     { lldb::eArgTypeRegularExpression, "regular-expression", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "A POSIX-compliant 
extended regular expression." },
-    { lldb::eArgTypeRunArgs, "run-args", lldb::CompletionType::eNoCompletion, 
{}, { nullptr, false }, "Arguments to be passed to the target program when it 
starts executing." },
+    { lldb::eArgTypeRunArgs, "run-args", 
lldb::CompletionType::eDiskFileCompletion, {}, { nullptr, false }, "Arguments 
to be passed to the target program when it starts executing." },
     { lldb::eArgTypeRunMode, "run-mode", lldb::CompletionType::eNoCompletion, 
g_running_mode, { nullptr, false }, "Help text goes here." },
     { lldb::eArgTypeScriptedCommandSynchronicity, "script-cmd-synchronicity", 
lldb::CompletionType::eNoCompletion, g_script_synchro_type, { nullptr, false }, 
"The synchronicity to use to run scripted commands with regard to LLDB event 
system." },
     { lldb::eArgTypeScriptLang, "script-language", 
lldb::CompletionType::eNoCompletion, g_script_option_enumeration, { nullptr, 
false }, "The scripting language to be used for script-based commands.  
Supported languages are python and lua." },
@@ -270,21 +270,21 @@ static constexpr CommandObject::ArgumentTableEntry 
g_argument_table[] = {
     { lldb::eArgTypeSelector, "selector", lldb::CompletionType::eNoCompletion, 
{}, { nullptr, false }, "An Objective-C selector name." },
     { lldb::eArgTypeSettingIndex, "setting-index", 
lldb::CompletionType::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)." },
     { lldb::eArgTypeSettingKey, "setting-key", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "A key into a 
settings variables that is a dictionary (try 'settings list' to see all the 
possible settings variables and their types)." },
-    { lldb::eArgTypeSettingPrefix, "setting-prefix", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of a 
settable internal debugger variable up to a dot ('.'), e.g. 'target.process.'" 
},
-    { lldb::eArgTypeSettingVariableName, "setting-variable-name", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of a 
settable internal debugger variable.  Type 'settings list' to see a complete 
list of such variables." },
-    { lldb::eArgTypeShlibName, "shlib-name", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The name of a 
shared library." },
+    { lldb::eArgTypeSettingPrefix, "setting-prefix", 
lldb::CompletionType::eSettingsNameCompletion, {}, { nullptr, false }, "The 
name of a settable internal debugger variable up to a dot ('.'), e.g. 
'target.process.'" },
+    { lldb::eArgTypeSettingVariableName, "setting-variable-name", 
lldb::CompletionType::eSettingsNameCompletion, {}, { nullptr, false }, "The 
name of a settable internal debugger variable.  Type 'settings list' to see a 
complete list of such variables." },
+    { lldb::eArgTypeShlibName, "shlib-name", 
lldb::CompletionType::eDiskFileCompletion, {}, { nullptr, false }, "The name of 
a shared library." },
     { lldb::eArgTypeSourceFile, "source-file", lldb::eSourceFileCompletion, 
{}, { nullptr, false }, "The name of a source file.." },
     { lldb::eArgTypeSortOrder, "sort-order", 
lldb::CompletionType::eNoCompletion, g_sort_option_enumeration, { nullptr, 
false }, "Specify a sort order when dumping lists." },
     { lldb::eArgTypeStartAddress, "start-address", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "Help text goes 
here." },
     { lldb::eArgTypeSummaryString, "summary-string", 
lldb::CompletionType::eNoCompletion, {}, { SummaryStringHelpTextCallback, true 
}, nullptr },
     { lldb::eArgTypeSymbol, "symbol", lldb::eSymbolCompletion, {}, { nullptr, 
false }, "Any symbol name (function name, variable, argument, etc.)" },
-    { lldb::eArgTypeThreadID, "thread-id", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "Thread ID 
number." },
-    { lldb::eArgTypeThreadIndex, "thread-index", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "Index into the 
process' list of threads." },
+    { lldb::eArgTypeThreadID, "thread-id", 
lldb::CompletionType::eThreadIndexCompletion, {}, { nullptr, false }, "Thread 
ID number." },
+    { lldb::eArgTypeThreadIndex, "thread-index", 
lldb::CompletionType::eThreadIndexCompletion, {}, { nullptr, false }, "Index 
into the process' list of threads." },
     { lldb::eArgTypeThreadName, "thread-name", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The thread's 
name." },
     { lldb::eArgTypeTypeName, "type-name", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "A type name." },
     { lldb::eArgTypeUnsignedInteger, "unsigned-integer", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "An unsigned 
integer." },
     { lldb::eArgTypeUnixSignal, "unix-signal", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "A valid Unix 
signal name or number (e.g. SIGKILL, KILL or 9)." },
-    { lldb::eArgTypeVarName, "variable-name", 
lldb::CompletionType::eNoCompletion, {} ,{ nullptr, false }, "The name of a 
variable in your program." },
+    { lldb::eArgTypeVarName, "variable-name", 
lldb::CompletionType::eVariablePathCompletion, {} ,{ nullptr, false }, "The 
name of a variable in your program." },
     { lldb::eArgTypeValue, "value", lldb::CompletionType::eNoCompletion, 
g_dependents_enumeration, { nullptr, false }, "A value could be anything, 
depending on where and how it is used." },
     { lldb::eArgTypeWidth, "width", lldb::CompletionType::eNoCompletion, {}, { 
nullptr, false }, "Help text goes here." },
     { lldb::eArgTypeNone, "none", lldb::CompletionType::eNoCompletion, {}, { 
nullptr, false }, "No help available for this." },
@@ -302,8 +302,11 @@ static constexpr CommandObject::ArgumentTableEntry 
g_argument_table[] = {
     { lldb::eArgTypeRecognizerID, "frame-recognizer-id", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The ID for a 
stack frame recognizer." },
     { lldb::eArgTypeConnectURL, "process-connect-url", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "A URL-style 
specification for a remote connection." },
     { lldb::eArgTypeTargetID, "target-id", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The index ID for 
an lldb Target." },
-    { lldb::eArgTypeStopHookID, "stop-hook-id", 
lldb::CompletionType::eNoCompletion, {}, { nullptr, false }, "The ID you 
receive when you create a stop-hook." },
+    { lldb::eArgTypeStopHookID, "stop-hook-id", 
lldb::CompletionType::eStopHookIDCompletion, {}, { nullptr, false }, "The ID 
you receive when you create a stop-hook." },
     { lldb::eArgTypeCompletionType, "completion-type", 
lldb::CompletionType::eNoCompletion, g_completion_type, { nullptr, false }, 
"The completion type to use when adding custom commands. If none is specified, 
the command won't use auto-completion." },
+    { lldb::eArgTypeRemotePath, "remote-path", 
lldb::CompletionType::eRemoteDiskFileCompletion, {}, { nullptr, false }, "A 
path on the system managed by the current platform." },
+    { lldb::eArgTypeRemoteFilename, "remote-filename", 
lldb::CompletionType::eRemoteDiskFileCompletion, {}, { nullptr, false }, "A 
file on the system managed by the current platform." },
+    { lldb::eArgTypeModule, "module", lldb::CompletionType::eModuleCompletion, 
{}, { nullptr, false }, "The name of a module loaded into the current target." 
},
     // clang-format on
 };
 
diff --git a/lldb/include/lldb/lldb-enumerations.h 
b/lldb/include/lldb/lldb-enumerations.h
index 50cbccba4d7c56..adcf7e874c855e 100644
--- a/lldb/include/lldb/lldb-enumerations.h
+++ b/lldb/include/lldb/lldb-enumerations.h
@@ -677,6 +677,9 @@ enum CommandArgumentType {
   eArgTypeTargetID,
   eArgTypeStopHookID,
   eArgTypeCompletionType,
+  eArgTypeRemotePath,
+  eArgTypeRemoteFilename,
+  eArgTypeModule,
   eArgTypeLastArg // Always keep this entry as the last entry in this
                   // enumeration!!
 };
diff --git a/lldb/source/Commands/CommandObjectCommands.cpp 
b/lldb/source/Commands/CommandObjectCommands.cpp
index a51e5ab1af30c6..73671b0fa70719 100644
--- a/lldb/source/Commands/CommandObjectCommands.cpp
+++ b/lldb/source/Commands/CommandObjectCommands.cpp
@@ -63,13 +63,6 @@ class CommandObjectCommandsSource : public 
CommandObjectParsed {
     return std::string("");
   }
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eDiskFileCompletion, request, nullptr);
-  }
-
   Options *GetOptions() override { return &m_options; }
 
 protected:
@@ -1272,13 +1265,6 @@ class CommandObjectCommandsScriptImport : public 
CommandObjectParsed {
 
   ~CommandObjectCommandsScriptImport() override = default;
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eDiskFileCompletion, request, nullptr);
-  }
-
   Options *GetOptions() override { return &m_options; }
 
 protected:
diff --git a/lldb/source/Commands/CommandObjectDWIMPrint.cpp 
b/lldb/source/Commands/CommandObjectDWIMPrint.cpp
index 695f3d7931cd0a..fb2cc106ffd2dd 100644
--- a/lldb/source/Commands/CommandObjectDWIMPrint.cpp
+++ b/lldb/source/Commands/CommandObjectDWIMPrint.cpp
@@ -52,12 +52,6 @@ 
CommandObjectDWIMPrint::CommandObjectDWIMPrint(CommandInterpreter &interpreter)
 
 Options *CommandObjectDWIMPrint::GetOptions() { return &m_option_group; }
 
-void CommandObjectDWIMPrint::HandleArgumentCompletion(
-    CompletionRequest &request, OptionElementVector &opt_element_vector) {
-  lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-      GetCommandInterpreter(), lldb::eVariablePathCompletion, request, 
nullptr);
-}
-
 void CommandObjectDWIMPrint::DoExecute(StringRef command,
                                        CommandReturnObject &result) {
   m_option_group.NotifyOptionParsingStarting(&m_exe_ctx);
diff --git a/lldb/source/Commands/CommandObjectDWIMPrint.h 
b/lldb/source/Commands/CommandObjectDWIMPrint.h
index d868f8964c2ac5..01ba9c225e3301 100644
--- a/lldb/source/Commands/CommandObjectDWIMPrint.h
+++ b/lldb/source/Commands/CommandObjectDWIMPrint.h
@@ -39,10 +39,6 @@ class CommandObjectDWIMPrint : public CommandObjectRaw {
 
   bool WantsCompletion() override { return true; }
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override;
-
 private:
   void DoExecute(llvm::StringRef command, CommandReturnObject &result) 
override;
 
diff --git a/lldb/source/Commands/CommandObjectFrame.cpp 
b/lldb/source/Commands/CommandObjectFrame.cpp
index 17a7e858b24e58..b39b1a006c1f7b 100644
--- a/lldb/source/Commands/CommandObjectFrame.cpp
+++ b/lldb/source/Commands/CommandObjectFrame.cpp
@@ -283,16 +283,6 @@ class CommandObjectFrameSelect : public 
CommandObjectParsed {
 
   ~CommandObjectFrameSelect() override = default;
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    if (request.GetCursorIndex() != 0)
-      return;
-
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eFrameIndexCompletion, request, 
nullptr);
-  }
-
   Options *GetOptions() override { return &m_options; }
 
 protected:
@@ -443,15 +433,6 @@ may even involve JITing and running code in the target 
program.)");
 
   Options *GetOptions() override { return &m_option_group; }
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    // Arguments are the standard source file completer.
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eVariablePathCompletion, request,
-        nullptr);
-  }
-
 protected:
   llvm::StringRef GetScopeString(VariableSP var_sp) {
     if (!var_sp)
diff --git a/lldb/source/Commands/CommandObjectPlatform.cpp 
b/lldb/source/Commands/CommandObjectPlatform.cpp
index 790f1dbb475358..7b960029d3cf28 100644
--- a/lldb/source/Commands/CommandObjectPlatform.cpp
+++ b/lldb/source/Commands/CommandObjectPlatform.cpp
@@ -418,7 +418,7 @@ class CommandObjectPlatformMkDir : public 
CommandObjectParsed {
       : CommandObjectParsed(interpreter, "platform mkdir",
                             "Make a new directory on the remote end.", nullptr,
                             0) {
-    CommandArgumentData thread_arg{eArgTypePath, eArgRepeatPlain};
+    CommandArgumentData thread_arg{eArgTypeRemotePath, eArgRepeatPlain};
     m_arguments.push_back({thread_arg});
   }
 
@@ -467,21 +467,12 @@ class CommandObjectPlatformFOpen : public 
CommandObjectParsed {
   CommandObjectPlatformFOpen(CommandInterpreter &interpreter)
       : CommandObjectParsed(interpreter, "platform file open",
                             "Open a file on the remote end.", nullptr, 0) {
-    CommandArgumentData path_arg{eArgTypePath, eArgRepeatPlain};
+    CommandArgumentData path_arg{eArgTypeRemotePath, eArgRepeatPlain};
     m_arguments.push_back({path_arg});
   }
 
   ~CommandObjectPlatformFOpen() override = default;
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    if (request.GetCursorIndex() == 0)
-      lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-          GetCommandInterpreter(), lldb::eRemoteDiskFileCompletion, request,
-          nullptr);
-  }
-
   void DoExecute(Args &args, CommandReturnObject &result) override {
     PlatformSP platform_sp(
         GetDebugger().GetPlatformList().GetSelectedPlatform());
@@ -795,7 +786,7 @@ class CommandObjectPlatformGetFile : public 
CommandObjectParsed {
     CommandArgumentData file_arg_remote, file_arg_host;
 
     // Define the first (and only) variant of this arg.
-    file_arg_remote.arg_type = eArgTypeFilename;
+    file_arg_remote.arg_type = eArgTypeRemoteFilename;
     file_arg_remote.arg_repetition = eArgRepeatPlain;
     // There is only one variant this argument could be; put it into the
     // argument entry.
@@ -876,7 +867,7 @@ class CommandObjectPlatformGetSize : public 
CommandObjectParsed {
     CommandArgumentData file_arg_remote;
 
     // Define the first (and only) variant of this arg.
-    file_arg_remote.arg_type = eArgTypeFilename;
+    file_arg_remote.arg_type = eArgTypeRemoteFilename;
     file_arg_remote.arg_repetition = eArgRepeatPlain;
     // There is only one variant this argument could be; put it into the
     // argument entry.
@@ -888,17 +879,6 @@ class CommandObjectPlatformGetSize : public 
CommandObjectParsed {
 
   ~CommandObjectPlatformGetSize() override = default;
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    if (request.GetCursorIndex() != 0)
-      return;
-
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eRemoteDiskFileCompletion, request,
-        nullptr);
-  }
-
   void DoExecute(Args &args, CommandReturnObject &result) override {
     // If the number of arguments is incorrect, issue an error message.
     if (args.GetArgumentCount() != 1) {
@@ -946,7 +926,7 @@ class CommandObjectPlatformGetPermissions : public 
CommandObjectParsed {
     CommandArgumentData file_arg_remote;
 
     // Define the first (and only) variant of this arg.
-    file_arg_remote.arg_type = eArgTypeFilename;
+    file_arg_remote.arg_type = eArgTypeRemoteFilename;
     file_arg_remote.arg_repetition = eArgRepeatPlain;
     // There is only one variant this argument could be; put it into the
     // argument entry.
@@ -958,17 +938,6 @@ class CommandObjectPlatformGetPermissions : public 
CommandObjectParsed {
 
   ~CommandObjectPlatformGetPermissions() override = default;
 
-  void
-  HandleArgumentCompletion(CompletionRequest &request,
-                           OptionElementVector &opt_element_vector) override {
-    if (request.GetCursorIndex() != 0)
-      return;
-
-    lldb_private::CommandCompletions::InvokeCommonCompletionCallbacks(
-        GetCommandInterpreter(), lldb::eRemoteDiskFileCompletion, request,
-        nullptr);
-  }
-
   void DoExecute(Args &args, CommandReturnObject &result) override {
     // If the number of arguments is incorrect, issue an error message.
     if (args.GetArgumentCount() != 1) {
@@ -1015,7 +984,7 @@ cla...
[truncated]

``````````

</details>


https://github.com/llvm/llvm-project/pull/82085
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to