26#include "llvm/ADT/StringRef.h"
34#define LLDB_OPTIONS_source
35#include "CommandOptions.inc"
41 interpreter,
"command source",
42 "Read and execute LLDB commands from the file <filename>.",
50 uint32_t index)
override {
51 return std::string(
"");
70 switch (short_option) {
88 llvm_unreachable(
"Unimplemented option");
102 return llvm::ArrayRef(g_source_options);
116 "'%s' takes exactly one executable filename argument.\n",
125 result.
AppendError(
"command source -C can only be specified "
126 "from a command file");
132 FileSpec cmd_file(command[0].ref());
136 result.
AppendError(
"command source -C can only be used "
137 "with a relative path.");
175#pragma mark CommandObjectCommandsAlias
178#define LLDB_OPTIONS_alias
179#include "CommandOptions.inc"
182 "Enter your Python command(s). Type 'DONE' to end.\n"
183 "You must define a Python function with this signature:\n"
184 "def my_command_impl(debugger, args, exe_ctx, result, internal_dict):\n";
195 return llvm::ArrayRef(g_alias_options);
202 const int short_option =
GetDefinitions()[option_idx].short_option;
203 std::string option_str(option_value);
205 switch (short_option) {
217 llvm_unreachable(
"Unimplemented option");
240 interpreter,
"command alias",
241 "Define a custom command in terms of an existing command.") {
246 "'alias' allows the user to create a short-cut or abbreviation for long \
247commands, multi-word commands, and commands that take particular options. \
248Below are some simple examples of how one might use the 'alias' command:"
251(lldb) command alias sc script
253 Creates the abbreviation 'sc' for the 'script' command.
255(lldb) command alias bp breakpoint
258 " Creates the abbreviation 'bp' for the 'breakpoint' command. Since \
259breakpoint commands are two-word commands, the user would still need to \
260enter the second word after 'bp', e.g. 'bp enable' or 'bp delete'."
263(lldb) command alias bpl breakpoint list
265 Creates the abbreviation 'bpl' for the two-word command 'breakpoint list'.
268 "An alias can include some options for the command, with the values either \
269filled in at the time the alias is created, or specified as positional \
270arguments, to be filled in when the alias is invoked. The following example \
271shows how to create aliases with options:"
274(lldb) command alias bfl breakpoint set -f %1 -l %2
277 " Creates the abbreviation 'bfl' (for break-file-line), with the -f and -l \
278options already part of the alias. So if the user wants to set a breakpoint \
279by file and line without explicitly having to use the -f and -l options, the \
280user can now use 'bfl' instead. The '%1' and '%2' are positional placeholders \
281for the actual arguments that will be passed when the alias command is used. \
282The number in the placeholder refers to the position/order the actual value \
283occupies when the alias is used. All the occurrences of '%1' in the alias \
284will be replaced with the first argument, all the occurrences of '%2' in the \
285alias will be replaced with the second argument, and so on. This also allows \
286actual arguments to be used multiple times within an alias (see 'process \
287launch' example below)."
291 "Note: the positional arguments must substitute as whole words in the resultant \
292command, so you can't at present do something like this to append the file extension \
296(lldb) command alias bcppfl breakpoint set -f %1.cpp -l %2
299 "For more complex aliasing, use the \"command regex\" command instead. In the \
300'bfl' case above, the actual file value will be filled in with the first argument \
301following 'bfl' and the actual line number value will be filled in with the second \
302argument. The user would use this alias as follows:"
305(lldb) command alias bfl breakpoint set -f %1 -l %2
306(lldb) bfl my-file.c 137
308This would be the same as if the user had entered 'breakpoint set -f my-file.c -l 137'.
312(lldb) command alias pltty process launch -s -o %1 -e %1
313(lldb) pltty /dev/tty0
315 Interpreted as 'process launch -s -o /dev/tty0 -e /dev/tty0'
318 "If the user always wanted to pass the same value to a particular option, the \
319alias could be defined with that value directly in the alias as a constant, \
320rather than using a positional placeholder:"
323(lldb) command alias bl3 breakpoint set -f %1 -l 3
325 Always sets a breakpoint on line 3 of whatever file is indicated.
329 "If the alias abbreviation or the full alias command collides with another \
330existing command, the command resolver will prefer to use the alias over any \
331other command as far as there is only one alias command match.");
346 arg1.push_back(alias_arg);
354 arg2.push_back(cmd_arg);
362 arg3.push_back(options_arg);
373 void DoExecute(llvm::StringRef raw_command_line,
375 if (raw_command_line.empty()) {
376 result.
AppendError(
"'command alias' requires at least two arguments");
385 if (args_with_suffix.HasArgs())
390 llvm::StringRef raw_command_string = args_with_suffix.GetRawPart();
391 Args args(raw_command_string);
393 if (args.GetArgumentCount() < 2) {
394 result.
AppendError(
"'command alias' requires at least two arguments");
400 auto alias_command = args[0].ref();
401 if (alias_command.starts_with(
"-")) {
402 result.
AppendError(
"aliases starting with a dash are not supported");
403 if (alias_command ==
"--help" || alias_command ==
"--long-help") {
404 result.
AppendWarning(
"if trying to pass options to 'command alias' add "
405 "a -- at the end of the options");
412 size_t pos = raw_command_string.find(alias_command);
414 raw_command_string = raw_command_string.substr(alias_command.size());
415 pos = raw_command_string.find_first_not_of(
' ');
416 if ((pos != std::string::npos) && (pos > 0))
417 raw_command_string = raw_command_string.substr(pos);
419 result.
AppendError(
"Error parsing command string. No alias created.");
426 "'%s' is a permanent debugger command and cannot be redefined.\n",
433 "'%s' is a user container command and cannot be overwritten.\n"
434 "Delete it first with 'command container delete'\n",
442 llvm::StringRef original_raw_command_string = raw_command_string;
448 "'%s' does not begin with a valid command."
449 " No alias created.",
450 original_raw_command_string.str().c_str());
463 llvm::StringRef raw_command_string,
471 const bool include_aliases =
true;
479 cmd_obj_sp = cmd_obj.shared_from_this();
484 "Overwriting existing definition for '%s'.\n",
485 alias_command.str().c_str());
488 alias_command, cmd_obj_sp, raw_command_string)) {
495 result.
AppendError(
"Unable to create requested alias.\n");
504 result.
AppendError(
"'command alias' requires at least two arguments");
509 const std::string alias_command(std::string(args[0].ref()));
510 const std::string actual_command(std::string(args[1].ref()));
520 "'%s' is a permanent debugger command and cannot be redefined.\n",
521 alias_command.c_str());
527 "'%s' is user container command and cannot be overwritten.\n"
528 "Delete it first with 'command container delete'",
529 alias_command.c_str());
536 bool use_subcommand =
false;
537 if (!command_obj_sp) {
539 actual_command.c_str());
548 auto sub_command = args[0].ref();
549 assert(!sub_command.empty());
551 if (!subcommand_obj_sp) {
553 "'%s' is not a valid sub-command of '%s'. "
554 "Unable to create alias.\n",
555 args[0].c_str(), actual_command.c_str());
559 sub_cmd_obj = subcommand_obj_sp.get();
560 use_subcommand =
true;
562 cmd_obj = sub_cmd_obj;
567 std::string args_string;
581 "Overwriting existing definition for '%s'.\n", alias_command.c_str());
585 alias_command, use_subcommand ? subcommand_obj_sp : command_obj_sp,
593 result.
AppendError(
"Unable to create requested alias.\n");
601#pragma mark CommandObjectCommandsUnalias
608 interpreter,
"command unalias",
609 "Delete one or more custom commands defined by 'command alias'.",
629 CommandObject::CommandMap::iterator pos;
633 result.
AppendError(
"must call 'unalias' with a valid alias");
637 auto command_name = args[0].ref();
641 "'%s' is not a known command.\nTry 'help' to see a "
642 "current list of commands.\n",
650 "'%s' is not an alias, it is a debugger command which can be "
651 "removed using the 'command delete' command.\n",
655 "'%s' is a permanent debugger command and cannot be removed.\n",
664 "Error occurred while attempting to unalias '%s'.\n",
676#pragma mark CommandObjectCommandsDelete
683 interpreter,
"command delete",
684 "Delete one or more custom commands defined by 'command regex'.",
698 if (ent.second->IsRemovable())
705 CommandObject::CommandMap::iterator pos;
709 "defined regular expression command names",
714 auto command_name = args[0].ref();
717 const bool generate_upropos =
true;
718 const bool generate_type_lookup =
false;
720 &error_msg_stream, command_name, llvm::StringRef(), llvm::StringRef(),
721 generate_upropos, generate_type_lookup);
728 "'%s' is a permanent debugger command and cannot be removed.\n",
739#define LLDB_OPTIONS_regex
740#include "CommandOptions.inc"
742#pragma mark CommandObjectCommandsAddRegex
749 interpreter,
"command regex",
750 "Define a custom command in terms of "
751 "existing commands by matching "
752 "regular expressions.",
753 "command regex <cmd-name> [s/<regex>/<subst>/ ...]"),
759 "This command allows the user to create powerful regular expression commands \
760with substitutions. The regular expressions and substitutions are specified \
761using the regular expression substitution format of:"
767 "<regex> is a regular expression that can use parenthesis to capture regular \
768expression input and substitute the captured matches in the output using %1 \
769for the first match, %2 for the second, and so on."
773 "The regular expressions can all be specified on the command line if more than \
774one argument is provided. If just the command name is provided on the command \
775line, then the regular expressions and substitutions can be entered on separate \
776lines, followed by an empty line to terminate the command definition."
782 "The following example will define a regular expression command named 'f' that \
783will call 'finish' if there are no arguments, or 'frame select <frame-idx>' if \
784a number follows 'f':"
787 (lldb) command regex f s/^$/finish/ 's/([0-9]+)/frame select %1/')");
796 if (output_sp && interactive) {
797 output_sp->PutCString(
"Enter one or more sed substitution commands in "
798 "the form: 's/<regex>/<subst>/'.\nTerminate the "
799 "substitution list with an empty line.\n");
805 std::string &data)
override {
810 bool check_only =
false;
811 for (
const std::string &line : lines) {
816 out_stream->Printf(
"error: %s\n",
error.AsCString());
831 result.
AppendError(
"usage: 'command regex <command-name> "
832 "[s/<regex1>/<subst1>/ s/<regex2>/<subst2>/ ...]'\n");
837 auto name = command[0].ref();
845 const bool multiple_lines =
true;
847 debugger, IOHandler::Type::Other,
849 llvm::StringRef(
"> "),
851 multiple_lines, color_prompt,
860 for (
auto &entry : command.
entries().drop_front()) {
861 bool check_only =
false;
867 if (
error.Success()) {
882 "invalid regular expression command object for: '%.*s'",
883 (
int)regex_sed.size(), regex_sed.data());
887 size_t regex_sed_size = regex_sed.size();
889 if (regex_sed_size <= 1) {
891 "regular expression substitution string is too short: '%.*s'",
892 (
int)regex_sed.size(), regex_sed.data());
896 if (regex_sed[0] !=
's') {
898 "regular expression substitution string "
899 "doesn't start with 's': '%.*s'",
900 (
int)regex_sed.size(), regex_sed.data());
903 const size_t first_separator_char_pos = 1;
906 const char separator_char = regex_sed[first_separator_char_pos];
907 const size_t second_separator_char_pos =
908 regex_sed.find(separator_char, first_separator_char_pos + 1);
910 if (second_separator_char_pos == std::string::npos) {
912 "missing second '%c' separator char after '%.*s' in '%.*s'",
914 (
int)(regex_sed.size() - first_separator_char_pos - 1),
915 regex_sed.data() + (first_separator_char_pos + 1),
916 (
int)regex_sed.size(), regex_sed.data());
920 const size_t third_separator_char_pos =
921 regex_sed.find(separator_char, second_separator_char_pos + 1);
923 if (third_separator_char_pos == std::string::npos) {
925 "missing third '%c' separator char after '%.*s' in '%.*s'",
927 (
int)(regex_sed.size() - second_separator_char_pos - 1),
928 regex_sed.data() + (second_separator_char_pos + 1),
929 (
int)regex_sed.size(), regex_sed.data());
933 if (third_separator_char_pos != regex_sed_size - 1) {
935 if (regex_sed.find_first_not_of(
"\t\n\v\f\r ",
936 third_separator_char_pos + 1) !=
939 "extra data found after the '%.*s' regular expression substitution "
941 (
int)third_separator_char_pos + 1, regex_sed.data(),
942 (
int)(regex_sed.size() - third_separator_char_pos - 1),
943 regex_sed.data() + (third_separator_char_pos + 1));
946 }
else if (first_separator_char_pos + 1 == second_separator_char_pos) {
948 "<regex> can't be empty in 's%c<regex>%c<subst>%c' string: '%.*s'",
949 separator_char, separator_char, separator_char, (
int)regex_sed.size(),
952 }
else if (second_separator_char_pos + 1 == third_separator_char_pos) {
954 "<subst> can't be empty in 's%c<regex>%c<subst>%c' string: '%.*s'",
955 separator_char, separator_char, separator_char, (
int)regex_sed.size(),
961 std::string regex(std::string(regex_sed.substr(
962 first_separator_char_pos + 1,
963 second_separator_char_pos - first_separator_char_pos - 1)));
964 std::string subst(std::string(regex_sed.substr(
965 second_separator_char_pos + 1,
966 third_separator_char_pos - second_separator_char_pos - 1)));
984 class CommandOptions :
public Options {
995 switch (short_option) {
997 m_help.assign(std::string(option_arg));
1000 m_syntax.assign(std::string(option_arg));
1003 llvm_unreachable(
"Unimplemented option");
1015 return llvm::ArrayRef(g_regex_options);
1037 std::string funct, std::string help,
1046 stream.
Printf(
"For more information run 'help %s'", name.c_str());
1061 return CommandObjectRaw::GetHelpLong();
1065 return CommandObjectRaw::GetHelpLong();
1067 std::string docstring;
1070 if (!docstring.empty())
1072 return CommandObjectRaw::GetHelpLong();
1131 stream.
Printf(
"For more information run 'help %s'", name.c_str());
1134 GetFlags().
Set(scripter->GetFlagsForCommandObject(cmd_obj_sp));
1153 uint32_t index)
override {
1156 return std::nullopt;
1163 return CommandObjectRaw::GetHelp();
1166 return CommandObjectRaw::GetHelp();
1167 std::string docstring;
1170 if (!docstring.empty())
1173 return CommandObjectRaw::GetHelp();
1178 return CommandObjectRaw::GetHelpLong();
1182 return CommandObjectRaw::GetHelpLong();
1184 std::string docstring;
1187 if (!docstring.empty())
1189 return CommandObjectRaw::GetHelpLong();
1254 "No script interpreter for SetOptionValue.");
1259 "SetOptionValue called with empty cmd_obj.");
1264 "SetOptionValue called before options definitions "
1271 const char * long_option =
1274 execution_context, long_option, option_arg);
1277 "Error setting option: {0} to {1}", long_option, option_arg);
1297 size_t counter, uint32_t &usage_mask) {
1316 uint32_t value = uint_val->
GetValue();
1319 "0 is not a valid group for option {0}", counter);
1321 usage_mask = (1 << (value - 1));
1328 "required field is not a array for option {0}", counter);
1332 auto groups_accumulator
1333 = [counter, &usage_mask, &
error]
1337 uint32_t value = int_val->
GetValue();
1340 "0 is not a valid group for element {0}", counter);
1343 usage_mask |= (1 << (value - 1));
1349 "Group element not an int or array of integers for element {0}",
1353 size_t num_range_elem = arr_val->
GetSize();
1354 if (num_range_elem != 2) {
1356 "Subranges of a group not a start and a stop for element {0}",
1363 "Start element of a subrange of a "
1364 "group not unsigned int for element {0}",
1368 uint32_t start = int_val->
GetValue();
1372 "End element of a subrange of a group"
1373 " not unsigned int for element {0}",
1377 uint32_t end = int_val->
GetValue();
1378 if (start == 0 || end == 0 || start > end) {
1380 "Invalid subrange of a group: {0} - "
1381 "{1} for element {2}",
1382 start, end, counter);
1385 for (uint32_t i = start; i <= end; i++) {
1386 usage_mask |= (1 << (i - 1));
1390 array_val->
ForEach(groups_accumulator);
1406 size_t short_opt_counter = 0;
1408 auto add_element = [
this, &
error, &counter, &short_opt_counter]
1413 "Value in options dictionary is not a dictionary");
1445 "'required' field is not a boolean "
1458 llvm::StringRef short_str = obj_sp->GetStringValue();
1459 if (short_str.empty()) {
1461 "short_option field empty for "
1465 }
else if (short_str.size() != 1) {
1467 "short_option field has extra "
1468 "characters for option {0}",
1472 short_option = (int) short_str[0];
1476 short_option = short_opt_counter++;
1481 if (long_option.empty()) {
1483 "empty long_option for option {0}", counter);
1487 option_def.
long_option = ((*(inserted.first)).data());
1496 "Value type must be an unsigned "
1500 uint64_t val_type = uint_val->
GetValue();
1504 "CommandArgumentType bounds",
1521 "Completion type must be an "
1522 "unsigned integer for option {0}",
1526 uint64_t completion_type = uint_val->
GetValue();
1529 "Completion type for option {0} "
1530 "beyond the CompletionType bounds",
1539 std::string usage_text;
1543 "required usage missing from option "
1548 llvm::StringRef usage_stref;
1549 usage_stref = obj_sp->GetStringValue();
1550 if (usage_stref.empty()) {
1552 "empty usage text for option {0}", counter);
1565 "enum values must be an array for "
1570 size_t num_elem = array->
GetSize();
1571 size_t enum_ctr = 0;
1572 m_enum_storage[counter] = std::vector<EnumValueStorage>(num_elem);
1573 std::vector<EnumValueStorage> &curr_elem =
m_enum_storage[counter];
1579 auto add_enum = [&enum_ctr, &curr_elem, counter, &
error]
1584 "Enum values for option {0} not "
1589 size_t num_enum_elements = enum_arr->
GetSize();
1590 if (num_enum_elements != 2) {
1592 "Wrong number of elements: {0} "
1593 "for enum {1} in option {2}",
1594 num_enum_elements, enum_ctr, counter);
1599 llvm::StringRef val_stref = obj_sp->GetStringValue();
1600 std::string value_cstr_str = val_stref.str().c_str();
1606 "No usage for enum {0} in option "
1611 llvm::StringRef usage_stref = obj_sp->GetStringValue();
1612 std::string usage_cstr_str = usage_stref.str().c_str();
1614 usage_cstr_str, enum_ctr);
1621 if (!
error.Success())
1625 for (
auto &elem : curr_elem)
1651 for (
auto option_elem : option_vec) {
1652 int cur_defs_index = option_elem.opt_defs_index;
1658 bool option_has_arg = opt_defs[cur_defs_index].option_has_arg;
1659 llvm::StringRef cur_arg_value;
1660 if (option_has_arg) {
1661 int cur_arg_pos = option_elem.opt_arg_pos;
1679 assert(completion_dict_sp &&
"Must have valid completion dict");
1681 llvm::StringRef completion;
1683 if (completion_dict_sp->GetValueForKeyAsString(
"no-completion",
1687 if (completion_dict_sp->GetValueForKeyAsString(
"completion",
1689 llvm::StringRef mode_str;
1691 if (completion_dict_sp->GetValueForKeyAsString(
"mode", mode_str)) {
1692 if (mode_str ==
"complete")
1693 mode = CompletionMode::Normal;
1694 else if (mode_str ==
"partial")
1695 mode = CompletionMode::Partial;
1707 if (completion_dict_sp->GetValueForKeyAsArray(
"values", completions)) {
1708 completion_dict_sp->GetValueForKeyAsArray(
"descriptions", descriptions);
1709 size_t num_completions = completions->
GetSize();
1710 for (
size_t idx = 0; idx < num_completions; idx++) {
1728 int opt_element_index,
1741 size_t defs_index = option_vec[opt_element_index].opt_defs_index;
1742 llvm::StringRef option_name = defs[defs_index].long_option;
1743 bool is_enum = defs[defs_index].enum_values.size() != 0;
1744 if (option_name.empty())
1750 completion_dict_sp =
1754 if (!completion_dict_sp) {
1756 opt_element_index, interpreter);
1772 size_t in_value) :
value(std::move(in_str_val)),
usage(std::move(in_usage)) {
1825 interpreter, name, cmd_obj_sp, synch));
1833 if (opt_error.
Fail())
1836 if (arg_error.
Fail())
1838 opt_error.
Fail() ?
", also " :
"",
1869 if (options_object_sp) {
1890 if (args_object_sp) {
1905 size_t elem_counter = 0;
1906 auto args_adder = [
this, counter, &elem_counter, &this_entry]
1912 uint32_t arg_opt_set_association;
1914 auto report_error = [
this, elem_counter,
1915 counter](
const char *err_txt) ->
bool {
1917 "Element {0} of arguments "
1918 "list element {1}: %s.",
1919 elem_counter, counter, err_txt);
1925 report_error(
"is not a dictionary.");
1935 report_error(
"value type must be an unsigned integer");
1938 uint64_t arg_type_int = uint_val->
GetValue();
1940 report_error(
"value type beyond ArgumentRepetitionType bounds");
1947 std::optional<ArgumentRepetitionType> repeat;
1949 llvm::StringRef repeat_str = obj_sp->GetStringValue();
1950 if (repeat_str.empty()) {
1951 report_error(
"repeat value is empty");
1956 report_error(
"invalid repeat value");
1959 arg_repetition = *repeat;
1965 counter, arg_opt_set_association);
1966 this_entry.emplace_back(arg_type, arg_repetition,
1967 arg_opt_set_association);
1975 "{0} is not an array",
1979 args_array->
ForEach(args_adder);
1982 if (this_entry.empty()) {
1994 args_array->
ForEach(arg_array_adder);
2039 std::unordered_set<size_t> option_slots;
2040 for (
const auto &elem : option_vec) {
2041 if (elem.opt_defs_index == -1)
2043 option_slots.insert(elem.opt_pos);
2044 if (defs[elem.opt_defs_index].option_has_arg)
2045 option_slots.insert(elem.opt_arg_pos);
2048 std::vector<llvm::StringRef> args_vec;
2052 size_t args_elem_pos = cursor_idx;
2054 for (
size_t idx = 0; idx < num_args; idx++) {
2055 if (option_slots.count(idx) == 0)
2056 args_vec.push_back(args[idx].ref());
2057 else if (idx < cursor_idx)
2064 if (!completion_dict_sp) {
2077 uint32_t index)
override {
2080 return std::nullopt;
2087 return CommandObjectParsed::GetHelp();
2090 return CommandObjectParsed::GetHelp();
2091 std::string docstring;
2094 if (!docstring.empty())
2097 return CommandObjectParsed::GetHelp();
2102 return CommandObjectParsed::GetHelpLong();
2106 return CommandObjectParsed::GetHelpLong();
2108 std::string docstring;
2111 if (!docstring.empty())
2113 return CommandObjectParsed::GetHelpLong();
2158std::unordered_set<std::string>
2162#define LLDB_OPTIONS_script_import
2163#include "CommandOptions.inc"
2169 "Import a scripting module in LLDB.", nullptr) {
2189 switch (short_option) {
2200 llvm_unreachable(
"Unimplemented option");
2211 return llvm::ArrayRef(g_script_import_options);
2218 if (command.
empty()) {
2219 result.
AppendError(
"command script import needs one or more arguments");
2227 result.
AppendError(
"command script import -c can only be specified "
2228 "from a command file");
2233 for (
auto &entry : command.
entries()) {
2249 if (
GetDebugger().GetScriptInterpreter()->LoadScriptingModule(
2250 entry.c_str(), options,
error,
nullptr,
2263#define LLDB_OPTIONS_script_add
2264#include "CommandOptions.inc"
2271 "Add a scripted function as an LLDB command.",
2272 "Add a scripted function as an lldb command. "
2273 "If you provide a single argument, the command "
2274 "will be added at the root level of the command "
2275 "hierarchy. If there are more arguments they "
2276 "must be a path to a user-added container "
2277 "command, and the last element will be the new "
2291 opt_element_vector);
2306 switch (short_option) {
2308 if (!option_arg.empty())
2312 if (!option_arg.empty())
2316 if (!option_arg.empty())
2329 if (!
error.Success())
2331 "unrecognized value for synchronicity '%s'",
2332 option_arg.str().c_str());
2340 if (!
error.Success())
2342 "unrecognized value for command completion type '%s'",
2343 option_arg.str().c_str());
2347 llvm_unreachable(
"Unimplemented option");
2364 return llvm::ArrayRef(g_script_add_options);
2381 if (output_sp && interactive) {
2388 std::string &data)
override {
2396 std::string funct_name_str;
2398 if (funct_name_str.empty()) {
2399 error_sp->Printf(
"error: unable to obtain a function name, didn't "
2400 "add python command.\n");
2412 error_sp->Printf(
"error: unable to add selected command: '%s'",
2420 error_sp->Printf(
"error: unable to add selected command: '%s'",
2421 llvm::toString(std::move(llvm_error)).c_str());
2428 "error: unable to create function, didn't add python command\n");
2432 error_sp->Printf(
"error: empty function, didn't add python command\n");
2437 "error: script interpreter missing, didn't add python command\n");
2446 result.
AppendError(
"only scripting language supported for scripted "
2447 "commands is currently Python");
2452 result.
AppendError(
"'command script add' requires at least one argument");
2470 command,
true, path_error);
2472 if (path_error.
Fail()) {
2483 m_cmd_name = std::string(command[num_args - 1].ref());
2505 result.
AppendError(
"cannot find ScriptInterpreter");
2533 if (add_error.
Fail())
2537 llvm::Error llvm_error =
2541 "cannot add command: %s",
2542 llvm::toString(std::move(llvm_error)).c_str());
2562 "List defined top-level scripted commands.",
2580 "Delete all scripted commands.", nullptr) {}
2598 interpreter,
"command script delete",
2599 "Delete a scripted command by specifying the path to the command.",
2616 llvm::StringRef root_cmd = command[0].ref();
2619 if (root_cmd.empty()) {
2626 "but no user defined commands found");
2633 command[0].c_str());
2636 if (!cmd_sp->IsUserCommand()) {
2638 command[0].c_str());
2641 if (cmd_sp->GetAsMultiwordCommand() && num_args == 1) {
2643 "Delete with \"command container delete\"",
2644 command[0].c_str());
2668 command[0].c_str());
2671 const char *leaf_cmd = command[num_args - 1].c_str();
2672 llvm::Error llvm_error =
2677 "could not delete command '%s': %s", leaf_cmd,
2678 llvm::toString(std::move(llvm_error)).c_str());
2684 out_stream <<
"Deleted command:";
2685 for (
size_t idx = 0; idx < num_args; idx++) {
2687 out_stream << command[idx].c_str();
2694#pragma mark CommandObjectMultiwordCommandsScript
2702 interpreter,
"command script",
2703 "Commands for managing custom "
2704 "commands implemented by "
2705 "interpreter scripts.",
2706 "command script <subcommand> [<subcommand-options>]") {
2725#pragma mark CommandObjectCommandContainer
2726#define LLDB_OPTIONS_container_add
2727#include "CommandOptions.inc"
2733 interpreter,
"command container add",
2734 "Add a container command to lldb. Adding to built-"
2735 "in container commands is not allowed.",
2736 "command container add [[path1]...] container-name") {
2763 switch (short_option) {
2765 if (!option_arg.empty())
2772 if (!option_arg.empty())
2776 llvm_unreachable(
"Unimplemented option");
2789 return llvm::ArrayRef(g_container_add_options);
2801 if (num_args == 0) {
2806 if (num_args == 1) {
2812 cmd_sp->GetAsMultiwordCommand()->SetRemovable(
true);
2815 if (add_error.
Fail()) {
2840 llvm::Error llvm_error =
2844 llvm::toString(std::move(llvm_error)).c_str());
2855#define LLDB_OPTIONS_multiword_delete
2856#include "CommandOptions.inc"
2861 interpreter,
"command container delete",
2862 "Delete a container command previously added to "
2864 "command container delete [[path1] ...] container-cmd") {
2881 if (num_args == 0) {
2886 if (num_args == 1) {
2898 if (!cmd_sp->IsUserCommand()) {
2900 "container command %s is not a user command", cmd_name);
2903 if (!cmd_sp->GetAsMultiwordCommand()) {
2931 llvm::Error llvm_error =
2935 llvm::toString(std::move(llvm_error)).c_str());
2946 interpreter,
"command container",
2947 "Commands for adding container commands to lldb. "
2948 "Container commands are containers for other commands. You can "
2949 "add nested container commands by specifying a command path, "
2950 "but you can't add commands into the built-in command hierarchy.",
2951 "command container <subcommand> [<subcommand-options>]") {
2962#pragma mark CommandObjectMultiwordCommands
2969 "Commands for managing custom LLDB commands.",
2970 "command <subcommand> [<subcommand-options>]") {
static const char * g_python_command_instructions
static llvm::raw_ostream & error(Stream &strm)
CommandObjectCommandContainer(CommandInterpreter &interpreter)
~CommandObjectCommandContainer() override=default
llvm::StringRef GetSyntax()
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
llvm::StringRef GetHelp()
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void OptionParsingStarting(ExecutionContext *execution_context) override
std::unique_ptr< CommandObjectRegexCommand > m_regex_cmd_up
void IOHandlerInputComplete(IOHandler &io_handler, std::string &data) override
Called when a line or lines have been retrieved.
~CommandObjectCommandsAddRegex() override=default
CommandObjectCommandsAddRegex(CommandInterpreter &interpreter)
Options * GetOptions() override
Status AppendRegexSubstitution(const llvm::StringRef ®ex_sed, bool check_only)
void DoExecute(Args &command, CommandReturnObject &result) override
void IOHandlerActivated(IOHandler &io_handler, bool interactive) override
void AddRegexCommandToInterpreter()
~CommandOptions() override=default
OptionValueString m_long_help
void OptionParsingStarting(ExecutionContext *execution_context) override
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_value, ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
bool HandleAliasingNormalCommand(Args &args, CommandReturnObject &result)
OptionGroupOptions m_option_group
CommandOptions m_command_options
void DoExecute(llvm::StringRef raw_command_line, CommandReturnObject &result) override
~CommandObjectCommandsAlias() override=default
Options * GetOptions() override
bool HandleAliasingRawCommand(llvm::StringRef alias_command, llvm::StringRef raw_command_string, CommandObject &cmd_obj, CommandReturnObject &result)
CommandObjectCommandsAlias(CommandInterpreter &interpreter)
~CommandOptions() override=default
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void OptionParsingStarting(ExecutionContext *execution_context) override
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
~CommandObjectCommandsContainerAdd() override=default
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
Options * GetOptions() override
CommandObjectCommandsContainerAdd(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectCommandsContainerDelete(CommandInterpreter &interpreter)
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
~CommandObjectCommandsContainerDelete() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectCommandsDelete(CommandInterpreter &interpreter)
void DoExecute(Args &args, CommandReturnObject &result) override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
~CommandObjectCommandsDelete() override=default
LazyBool m_overwrite_lazy
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
CompletionType m_completion_type
ScriptedCommandSynchronicity m_synchronicity
void OptionParsingStarting(ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void IOHandlerActivated(IOHandler &io_handler, bool interactive) override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectCommandsScriptAdd() override=default
void IOHandlerInputComplete(IOHandler &io_handler, std::string &data) override
Called when a line or lines have been retrieved.
CompletionType m_completion_type
ScriptedCommandSynchronicity m_synchronicity
Options * GetOptions() override
CommandObjectMultiword * m_container
CommandObjectCommandsScriptAdd(CommandInterpreter &interpreter)
CommandObjectCommandsScriptClear(CommandInterpreter &interpreter)
~CommandObjectCommandsScriptClear() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectCommandsScriptDelete() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectCommandsScriptDelete(CommandInterpreter &interpreter)
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
void OptionParsingStarting(ExecutionContext *execution_context) override
bool relative_to_command_file
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
~CommandOptions() override=default
CommandObjectCommandsScriptImport(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
Options * GetOptions() override
~CommandObjectCommandsScriptImport() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectCommandsScriptList() override=default
CommandObjectCommandsScriptList(CommandInterpreter &interpreter)
OptionValueBoolean m_cmd_relative_to_command_file
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
OptionValueBoolean m_stop_on_error
~CommandOptions() override=default
void OptionParsingStarting(ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
OptionValueBoolean m_stop_on_continue
OptionValueBoolean m_silent_run
std::optional< std::string > GetRepeatCommand(Args ¤t_command_args, uint32_t index) override
Get the command that appropriate for a "repeat" of the current command.
CommandObjectCommandsSource(CommandInterpreter &interpreter)
Options * GetOptions() override
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectCommandsSource() override=default
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
void DoExecute(Args &args, CommandReturnObject &result) override
CommandObjectCommandsUnalias(CommandInterpreter &interpreter)
~CommandObjectCommandsUnalias() override=default
~CommandObjectMultiwordCommandsScript() override=default
CommandObjectMultiwordCommandsScript(CommandInterpreter &interpreter)
std::string m_function_name
void DoExecute(llvm::StringRef raw_command_line, CommandReturnObject &result) override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
bool IsRemovable() const override
ScriptedCommandSynchronicity GetSynchronicity()
bool WantsCompletion() override
CommandObjectPythonFunction(CommandInterpreter &interpreter, std::string name, std::string funct, std::string help, ScriptedCommandSynchronicity synch, CompletionType completion_type)
ScriptedCommandSynchronicity m_synchro
llvm::StringRef GetHelpLong() override
const std::string & GetFunctionName()
CompletionType m_completion_type
~CommandObjectPythonFunction() override=default
StructuredData::GenericSP m_cmd_obj_sp
static Status ParseUsageMaskFromArray(StructuredData::ObjectSP obj_sp, size_t counter, uint32_t &usage_mask)
std::vector< std::string > m_usage_container
CommandInterpreter & m_interpreter
std::unique_ptr< OptionDefinition > m_options_definition_up
void OptionParsingStarting(ExecutionContext *execution_context) override
~CommandOptions() override=default
void HandleOptionArgumentCompletion(lldb_private::CompletionRequest &request, OptionElementVector &option_vec, int opt_element_index, CommandInterpreter &interpreter) override
Handles the generic bits of figuring out whether we are in an option, and if so completing it.
static std::unordered_set< std::string > g_string_storer
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
CommandOptions(CommandInterpreter &interpreter, StructuredData::GenericSP cmd_obj_sp)
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
std::vector< std::vector< OptionEnumValueElement > > m_enum_vector
void ProcessCompletionDict(CompletionRequest &request, StructuredData::DictionarySP &completion_dict_sp)
std::vector< std::vector< EnumValueStorage > > m_enum_storage
void PrepareOptionsForCompletion(CompletionRequest &request, OptionElementVector &option_vec, ExecutionContext *exe_ctx)
Status SetOptionsFromArray(StructuredData::Dictionary &options)
This command implements a lldb parsed scripted command.
llvm::StringRef GetHelpLong() override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &option_vec) override
The default version handles argument definitions that have only one argument type,...
bool IsRemovable() const override
CommandObjectScriptingObjectParsed(CommandInterpreter &interpreter, std::string name, StructuredData::GenericSP cmd_obj_sp, ScriptedCommandSynchronicity synch)
void DoExecute(Args &args, CommandReturnObject &result) override
Options * GetOptions() override
llvm::StringRef GetHelp() override
std::optional< std::string > GetRepeatCommand(Args &args, uint32_t index) override
Get the command that appropriate for a "repeat" of the current command.
~CommandObjectScriptingObjectParsed() override=default
void PrepareOptionsForCompletion(CompletionRequest &request, OptionElementVector &option_vec)
bool m_fetched_help_short
bool WantsCompletion() override
ScriptedCommandSynchronicity m_synchro
StructuredData::GenericSP m_cmd_obj_sp
ScriptedCommandSynchronicity GetSynchronicity()
static CommandObjectSP Create(CommandInterpreter &interpreter, std::string name, StructuredData::GenericSP cmd_obj_sp, ScriptedCommandSynchronicity synch, CommandReturnObject &result)
This class implements a "raw" scripted command.
CompletionType m_completion_type
bool WantsCompletion() override
llvm::StringRef GetHelp() override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
StructuredData::GenericSP m_cmd_obj_sp
std::optional< std::string > GetRepeatCommand(Args &args, uint32_t index) override
Get the command that appropriate for a "repeat" of the current command.
llvm::StringRef GetHelpLong() override
ScriptedCommandSynchronicity m_synchro
~CommandObjectScriptingObjectRaw() override=default
bool m_fetched_help_short
bool IsRemovable() const override
CommandObjectScriptingObjectRaw(CommandInterpreter &interpreter, std::string name, StructuredData::GenericSP cmd_obj_sp, ScriptedCommandSynchronicity synch, CompletionType completion_type)
ScriptedCommandSynchronicity GetSynchronicity()
void DoExecute(llvm::StringRef raw_command_line, CommandReturnObject &result) override
A command line argument class.
void Shift()
Shifts the first argument C string value of the array off the argument array.
size_t GetArgumentCount() const
Gets the number of arguments left in this command object.
llvm::ArrayRef< ArgEntry > entries() const
const char * GetArgumentAtIndex(size_t idx) const
Gets the NULL terminated C string argument pointer for the argument at index idx.
bool GetCommandString(std::string &command) const
static bool InvokeCommonCompletionCallbacks(CommandInterpreter &interpreter, uint32_t completion_mask, lldb_private::CompletionRequest &request, SearchFilter *searcher)
static void CompleteModifiableCmdPathArgs(CommandInterpreter &interpreter, CompletionRequest &request, OptionElementVector &opt_element_vector)
This completer works for commands whose only arguments are a command path.
void SetStopOnContinue(bool stop_on_continue)
void SetSilent(bool silent)
void SetPrintErrors(bool print_errors)
void SetEchoCommands(bool echo_commands)
void SetStopOnError(bool stop_on_error)
void SetPrintResults(bool print_results)
void SetEchoCommentCommands(bool echo_comments)
bool UserMultiwordCommandExists(llvm::StringRef cmd) const
Determine whether a root-level user multiword command with this name exists.
void IncreaseCommandUsage(const CommandObject &cmd_obj)
bool RemoveAlias(llvm::StringRef alias_name)
CommandAlias * AddAlias(llvm::StringRef alias_name, lldb::CommandObjectSP &command_obj_sp, llvm::StringRef args_string=llvm::StringRef())
CommandObject * GetCommandObject(llvm::StringRef cmd, StringList *matches=nullptr, StringList *descriptions=nullptr) const
ExecutionContext GetExecutionContext() const
CommandObjectMultiword * VerifyUserMultiwordCmdPath(Args &path, bool leaf_is_command, Status &result)
Look up the command pointed to by path encoded in the arguments of the incoming command object.
bool GetEchoCommentCommands() const
Status AddUserCommand(llvm::StringRef name, const lldb::CommandObjectSP &cmd_sp, bool can_replace)
bool AddCommand(llvm::StringRef name, const lldb::CommandObjectSP &cmd_sp, bool can_replace)
bool AliasExists(llvm::StringRef cmd) const
Determine whether an alias command with this name exists.
bool HasUserMultiwordCommands() const
void GetHelp(CommandReturnObject &result, uint32_t types=eCommandTypesAllThem)
bool CommandExists(llvm::StringRef cmd) const
Determine whether a root level, built-in command with this name exists.
bool GetRequireCommandOverwrite() const
void GetPythonCommandsFromIOHandler(const char *prompt, IOHandlerDelegate &delegate, void *baton=nullptr)
lldb::CommandObjectSP GetCommandSPExact(llvm::StringRef cmd, bool include_aliases=false) const
bool RemoveUser(llvm::StringRef alias_name)
CommandObject * GetCommandObjectForCommand(llvm::StringRef &command_line)
bool RemoveUserMultiword(llvm::StringRef multiword_name)
bool UserCommandExists(llvm::StringRef cmd) const
Determine whether a root-level user command with this name exists.
bool HasUserCommands() const
const CommandObject::CommandMap & GetCommands() const
void HandleCommandsFromFile(FileSpec &file, const ExecutionContext &context, const CommandInterpreterRunOptions &options, CommandReturnObject &result)
Execute a list of commands from a file.
FileSpec GetCurrentSourceDir()
bool RemoveCommand(llvm::StringRef cmd, bool force=false)
Remove a command if it is removable (python or regex command).
const CommandObject::CommandMap & GetAliases() const
bool GetEchoCommands() const
static void GenerateAdditionalHelpAvenuesMessage(Stream *s, llvm::StringRef command, llvm::StringRef prefix, llvm::StringRef subcommand, bool include_upropos=true, bool include_type_lookup=true)
~CommandObjectMultiwordCommands() override
CommandObjectMultiwordCommands(CommandInterpreter &interpreter)
llvm::Error LoadUserSubcommand(llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj, bool can_replace) override
bool LoadSubCommand(llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj) override
llvm::Error RemoveUserSubcommand(llvm::StringRef cmd_name, bool multiword_okay)
std::vector< CommandArgumentData > CommandArgumentEntry
virtual void SetHelpLong(llvm::StringRef str)
virtual bool WantsRawCommandString()=0
void AddSimpleArgumentList(lldb::CommandArgumentType arg_type, ArgumentRepetitionType repetition_type=eArgRepeatPlain)
bool ParseOptionsAndNotify(Args &args, CommandReturnObject &result, OptionGroupOptions &group_options, ExecutionContext &exe_ctx)
llvm::StringRef GetCommandName() const
static std::optional< ArgumentRepetitionType > ArgRepetitionFromString(llvm::StringRef string)
virtual bool IsMultiwordObject()
ExecutionContext m_exe_ctx
std::vector< CommandArgumentEntry > m_arguments
CommandInterpreter & GetCommandInterpreter()
CommandInterpreter & m_interpreter
Flags & GetFlags()
The flags accessor.
virtual void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector)
The default version handles argument definitions that have only one argument type,...
virtual bool IsRemovable() const
virtual void SetHelp(llvm::StringRef str)
virtual lldb::CommandObjectSP GetSubcommandSP(llvm::StringRef sub_cmd, StringList *matches=nullptr)
void AppendErrorWithFormatv(const char *format, Args &&... args)
void void AppendError(llvm::StringRef in_string)
void AppendWarningWithFormat(const char *format,...) __attribute__((format(printf
void SetStatus(lldb::ReturnStatus status)
void AppendErrorWithFormat(const char *format,...) __attribute__((format(printf
lldb::ReturnStatus GetStatus() const
void void AppendWarning(llvm::StringRef in_string)
Stream & GetOutputStream()
llvm::StringRef GetOutputString()
"lldb/Utility/ArgCompletionRequest.h"
void AddCompletion(llvm::StringRef completion, llvm::StringRef description="", CompletionMode mode=CompletionMode::Normal)
Adds a possible completion string.
const Args & GetParsedLine() const
size_t GetCursorCharPos() const
void TryCompleteCurrentArg(llvm::StringRef completion, llvm::StringRef description="")
Adds a possible completion string if the completion would complete the current argument.
size_t GetCursorIndex() const
A class to manage flag bits.
lldb::StreamSP GetAsyncOutputStream()
CommandInterpreter & GetCommandInterpreter()
void RunIOHandlerAsync(const lldb::IOHandlerSP &reader_sp, bool cancel_top_handler=true)
Run the given IO handler and return immediately.
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
void Clear()
Clear the object's state.
bool IsRelative() const
Returns true if the filespec represents a relative path.
void MakeAbsolute(const FileSpec &dir)
Make the FileSpec absolute by treating it relative to dir.
void Resolve(llvm::SmallVectorImpl< char > &path)
Resolve path to make it canonical.
static FileSystem & Instance()
ValueType Set(ValueType mask)
Set one or more flags by logical OR'ing mask with the current flags.
A delegate class for use with IOHandler subclasses.
lldb::StreamFileSP GetErrorStreamFileSP()
lldb::StreamFileSP GetOutputStreamFileSP()
LoadScriptOptions & SetInitSession(bool b)
LoadScriptOptions & SetSilent(bool b)
void Append(OptionGroup *group)
Append options from a OptionGroup class.
Status SetValueFromString(llvm::StringRef value, VarSetOperationType op=eVarSetOperationAssign) override
bool GetCurrentValue() const
const char * GetCurrentValue() const
Status SetCurrentValue(llvm::StringRef value)
bool OptionWasSet() const
A pair of an option list with a 'raw' string as a suffix.
A command line option parsing protocol class.
virtual void HandleOptionArgumentCompletion(lldb_private::CompletionRequest &request, OptionElementVector &opt_element_vector, int opt_element_index, CommandInterpreter &interpreter)
Handles the generic bits of figuring out whether we are in an option, and if so completing it.
virtual Status OptionParsingFinished(ExecutionContext *execution_context)
virtual llvm::ArrayRef< OptionDefinition > GetDefinitions()
void NotifyOptionParsingStarting(ExecutionContext *execution_context)
std::vector< Option > m_getopt_table
virtual bool SetOptionValueForCommandObject(StructuredData::GenericSP cmd_obj_sp, ExecutionContext *exe_ctx, llvm::StringRef long_option, llvm::StringRef value)
virtual StructuredData::GenericSP CreateScriptCommandObject(const char *class_name)
virtual bool RunScriptBasedCommand(const char *impl_function, llvm::StringRef args, ScriptedCommandSynchronicity synchronicity, lldb_private::CommandReturnObject &cmd_retobj, Status &error, const lldb_private::ExecutionContext &exe_ctx)
virtual bool GenerateScriptAliasFunction(StringList &input, std::string &output)
virtual StructuredData::DictionarySP HandleOptionArgumentCompletionForScriptedCommand(StructuredData::GenericSP impl_obj_sp, llvm::StringRef &long_name, size_t char_in_arg)
virtual std::optional< std::string > GetRepeatCommandForScriptedCommand(StructuredData::GenericSP impl_obj_sp, Args &args)
virtual bool GetDocumentationForItem(const char *item, std::string &dest)
virtual bool RunScriptBasedParsedCommand(StructuredData::GenericSP impl_obj_sp, Args &args, ScriptedCommandSynchronicity synchronicity, lldb_private::CommandReturnObject &cmd_retobj, Status &error, const lldb_private::ExecutionContext &exe_ctx)
virtual StructuredData::ObjectSP GetOptionsForCommandObject(StructuredData::GenericSP cmd_obj_sp)
virtual StructuredData::ObjectSP GetArgumentsForCommandObject(StructuredData::GenericSP cmd_obj_sp)
virtual void OptionParsingStartedForCommandObject(StructuredData::GenericSP cmd_obj_sp)
virtual bool GetLongHelpForCommandObject(StructuredData::GenericSP cmd_obj_sp, std::string &dest)
virtual uint32_t GetFlagsForCommandObject(StructuredData::GenericSP cmd_obj_sp)
virtual bool GetShortHelpForCommandObject(StructuredData::GenericSP cmd_obj_sp, std::string &dest)
virtual StructuredData::DictionarySP HandleArgumentCompletionForScriptedCommand(StructuredData::GenericSP impl_obj_sp, std::vector< llvm::StringRef > &args, size_t args_pos, size_t char_in_arg)
Status Clone() const
Don't call this function in new code.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
static Status static Status FromErrorStringWithFormatv(const char *format, Args &&...args)
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
size_t Printf(const char *format,...) __attribute__((format(printf
Output printf formatted output to the stream.
size_t SplitIntoLines(const std::string &lines)
ObjectSP GetItemAtIndex(size_t idx) const
bool ForEach(std::function< bool(Object *object)> const &foreach_callback) const
std::optional< llvm::StringRef > GetItemAtIndexAsString(size_t idx) const
ObjectSP GetValueForKey(llvm::StringRef key) const
void ForEach(std::function< bool(llvm::StringRef key, Object *object)> const &callback) const
Dictionary * GetAsDictionary()
UnsignedInteger * GetAsUnsignedInteger()
std::shared_ptr< Generic > GenericSP
std::shared_ptr< Dictionary > DictionarySP
std::shared_ptr< Object > ObjectSP
A class that represents a running process on the host machine.
std::vector< OptionArgElement > OptionElementVector
std::shared_ptr< OptionArgVector > OptionArgVectorSP
ScriptedCommandSynchronicity
@ eScriptedCommandSynchronicitySynchronous
std::vector< std::tuple< std::string, int, std::string > > OptionArgVector
std::shared_ptr< lldb_private::IOHandler > IOHandlerSP
std::shared_ptr< lldb_private::CommandObject > CommandObjectSP
std::shared_ptr< lldb_private::Stream > StreamSP
@ eReturnStatusSuccessFinishResult
@ eReturnStatusSuccessFinishNoResult
std::shared_ptr< lldb_private::StreamFile > StreamFileSP
OptionEnumValueElement element
EnumValueStorage(const EnumValueStorage &in)
EnumValueStorage & operator=(const EnumValueStorage &in)
void SetElement(size_t in_value)
EnumValueStorage(std::string in_str_val, std::string in_usage, size_t in_value)
Used to build individual command argument lists.
ArgumentRepetitionType arg_repetition
lldb::CommandArgumentType arg_type
static int64_t ToOptionEnum(llvm::StringRef s, const OptionEnumValues &enum_values, int32_t fail_value, Status &error)
OptionValidator * validator
If non-NULL, option is valid iff |validator->IsValid()|, otherwise always valid.
const char * long_option
Full name for this option.
const char * usage_text
Full text explaining what this options does and what (if any) argument to pass it.
bool required
This option is required (in the current usage level).
uint32_t completion_type
The kind of completion for this option.
int option_has_arg
no_argument, required_argument or optional_argument
uint32_t usage_mask
Used to mark options that can be used together.
lldb::CommandArgumentType argument_type
Type of argument this option takes.
OptionEnumValues enum_values
If not empty, an array of enum values.
int short_option
Single character for this option.
const char * string_value