1include "OptionsBase.td"
2
3let Command = "target modules dump symtab" in {
4  def tm_sort : Option<"sort", "s">, Group<1>,
5    Desc<"Supply a sort order when dumping the symbol table.">,
6    EnumArg<"SortOrder", "OptionEnumValues(g_sort_option_enumeration)">;
7  def tm_smn : Option<"show-mangled-names", "m">, Group<1>,
8    Desc<"Do not demangle symbol names before showing them.">;
9}
10
11let Command = "help" in {
12  def help_hide_aliases : Option<"hide-aliases", "a">,
13    Desc<"Hide aliases in the command list.">;
14  def help_hide_user : Option<"hide-user-commands", "u">,
15    Desc<"Hide user-defined commands from the list.">;
16  def help_show_hidden : Option<"show-hidden-commands", "h">,
17    Desc<"Include commands prefixed with an underscore.">;
18}
19
20let Command = "settings set" in {
21  def setset_global : Option<"global", "g">, Arg<"Filename">,
22    Completion<"DiskFile">,
23    Desc<"Apply the new value to the global default value.">;
24  def setset_force : Option<"force", "f">,
25    Desc<"Force an empty value to be accepted as the default.">;
26}
27
28let Command = "settings write" in {
29  def setwrite_file : Option<"file", "f">, Required, Arg<"Filename">,
30    Completion<"DiskFile">,
31    Desc<"The file into which to write the settings.">;
32  def setwrite_append : Option<"append", "a">,
33    Desc<"Append to saved settings file if it exists.">;
34}
35
36let Command = "settings read" in {
37  def setread_file : Option<"file", "f">, Required, Arg<"Filename">,
38    Completion<"DiskFile">,
39    Desc<"The file from which to read the settings.">;
40}
41
42let Command = "settings clear" in {
43  def setclear_all : Option<"all", "a">,
44    Desc<"Clear all settings.">;
45}
46
47let Command = "breakpoint list" in {
48  // FIXME: We need to add an "internal" command, and then add this sort of
49  // thing to it. But I need to see it for now, and don't want to wait.
50  def blist_internal : Option<"internal", "i">,
51    Desc<"Show debugger internal breakpoints">;
52  def blist_brief : Option<"brief", "b">, Group<1>,
53    Desc<"Give a brief description of the breakpoint (no location info).">;
54  def blist_full : Option<"full", "f">, Group<2>,
55    Desc<"Give a full description of the breakpoint and its locations.">;
56  def blist_verbose : Option<"verbose", "v">, Group<3>,
57    Desc<"Explain everything we know about the breakpoint (for debugging "
58    "debugger bugs).">;
59  def blist_dummy_bp : Option<"dummy-breakpoints", "D">,
60    Desc<"List Dummy breakpoints - i.e. breakpoints set before a file is "
61    "provided, which prime new targets.">;
62}
63
64let Command = "breakpoint modify" in {
65  def breakpoint_modify_ignore_count : Option<"ignore-count", "i">, Group<1>,
66    Arg<"Count">,
67    Desc<"Set the number of times this breakpoint is skipped before stopping.">;
68  def breakpoint_modify_one_shot : Option<"one-shot", "o">, Group<1>,
69    Arg<"Boolean">,
70    Desc<"The breakpoint is deleted the first time it stop causes a stop.">;
71  def breakpoint_modify_thread_index : Option<"thread-index", "x">, Group<1>,
72    Arg<"ThreadIndex">, Desc<"The breakpoint stops only for the thread whose "
73    "index matches this argument.">;
74  def breakpoint_modify_thread_id : Option<"thread-id", "t">, Group<1>,
75    Arg<"ThreadID">, Desc<"The breakpoint stops only for the thread whose TID "
76    "matches this argument.">;
77  def breakpoint_modify_thread_name : Option<"thread-name", "T">, Group<1>,
78    Arg<"ThreadName">, Desc<"The breakpoint stops only for the thread whose "
79    "thread name matches this argument.">;
80  def breakpoint_modify_queue_name : Option<"queue-name", "q">, Group<1>,
81    Arg<"QueueName">, Desc<"The breakpoint stops only for threads in the queue "
82    "whose name is given by this argument.">;
83  def breakpoint_modify_condition : Option<"condition", "c">, Group<1>,
84    Arg<"Expression">, Desc<"The breakpoint stops only if this condition "
85    "expression evaluates to true.">;
86  def breakpoint_modify_auto_continue : Option<"auto-continue", "G">, Group<1>,
87    Arg<"Boolean">,
88    Desc<"The breakpoint will auto-continue after running its commands.">;
89  def breakpoint_modify_enable : Option<"enable", "e">, Group<2>,
90    Desc<"Enable the breakpoint.">;
91  def breakpoint_modify_disable : Option<"disable", "d">, Group<3>,
92    Desc<"Disable the breakpoint.">;
93  def breakpoint_modify_command : Option<"command", "C">, Group<4>,
94    Arg<"Command">,
95    Desc<"A command to run when the breakpoint is hit, can be provided more "
96    "than once, the commands will get run in order left to right.">;
97}
98
99let Command = "breakpoint dummy" in {
100  def breakpoint_dummy_options_dummy_breakpoints :
101    Option<"dummy-breakpoints", "D">, Group<1>,
102    Desc<"Act on Dummy breakpoints - i.e. breakpoints set before a file is "
103    "provided, which prime new targets.">;
104}
105
106let Command = "breakpoint set" in {
107  def breakpoint_set_shlib : Option<"shlib", "s">, Arg<"ShlibName">,
108    Completion<"Module">, Groups<[1,2,3,4,5,6,7,8,9,11,12]>, // *not* in group 10
109    Desc<"Set the breakpoint only in this shared library.  Can repeat this "
110    "option multiple times to specify multiple shared libraries.">;
111  def breakpoint_set_hardware : Option<"hardware", "H">,
112    Desc<"Require the breakpoint to use hardware breakpoints.">;
113  def breakpoint_set_file : Option<"file", "f">, Arg<"Filename">,
114    Completion<"SourceFile">, Groups<[1,3,4,5,6,7,8,9,11]>,
115    Desc<"Specifies the source file in which to set this breakpoint.  Note, by "
116    "default lldb only looks for files that are #included if they use the "
117    "standard include file extensions.  To set breakpoints on .c/.cpp/.m/.mm "
118    "files that are #included, set target.inline-breakpoint-strategy to "
119    "\"always\".">;
120  def breakpoint_set_line : Option<"line", "l">, Group<1>, Arg<"LineNum">,
121    Required,
122    Desc<"Specifies the line number on which to set this breakpoint.">;
123  def breakpoint_set_column : Option<"column", "u">, Group<1>, Arg<"ColumnNum">,
124    Desc<"Specifies the column number on which to set this breakpoint.">;
125  def breakpoint_set_address : Option<"address", "a">, Group<2>,
126    Arg<"AddressOrExpression">, Required,
127    Desc<"Set the breakpoint at the specified address.  If the address maps "
128    "uniquely toa particular binary, then the address will be converted to "
129    "a \"file\"address, so that the breakpoint will track that binary+offset "
130    "no matter where the binary eventually loads.  Alternately, if you also "
131    "specify the module - with the -s option - then the address will be "
132    "treated as a file address in that module, and resolved accordingly.  "
133    "Again, this will allow lldb to track that offset on subsequent reloads. "
134    " The module need not have been loaded at the time you specify this "
135    "breakpoint, and will get resolved when the module is loaded.">;
136  def breakpoint_set_name : Option<"name", "n">, Group<3>, Arg<"FunctionName">,
137    Completion<"Symbol">, Required,
138    Desc<"Set the breakpoint by function name.  Can be repeated multiple times "
139    "to makeone breakpoint for multiple names">;
140  def breakpoint_set_source_regexp_function :
141    Option<"source-regexp-function", "X">, Group<9>, Arg<"FunctionName">,
142    Completion<"Symbol">,
143    Desc<"When used with '-p' limits the source regex to source contained in "
144    "the namedfunctions.  Can be repeated multiple times.">;
145  def breakpoint_set_fullname : Option<"fullname", "F">, Group<4>,
146    Arg<"FullName">, Required, Completion<"Symbol">,
147    Desc<"Set the breakpoint by fully qualified function names. For C++ this "
148    "means namespaces and all arguments, and for Objective-C this means a full "
149    "functionprototype with class and selector.  Can be repeated multiple times"
150    " to make one breakpoint for multiple names.">;
151  def breakpoint_set_selector : Option<"selector", "S">, Group<5>,
152    Arg<"Selector">, Required,
153    Desc<"Set the breakpoint by ObjC selector name. Can be repeated multiple "
154    "times tomake one breakpoint for multiple Selectors.">;
155  def breakpoint_set_method : Option<"method", "M">, Group<6>, Arg<"Method">,
156    Required, Desc<"Set the breakpoint by C++ method names.  Can be repeated "
157    "multiple times tomake one breakpoint for multiple methods.">;
158  def breakpoint_set_func_regex : Option<"func-regex", "r">, Group<7>,
159    Arg<"RegularExpression">, Required, Desc<"Set the breakpoint by function "
160    "name, evaluating a regular-expression to find the function name(s).">;
161  def breakpoint_set_basename : Option<"basename", "b">, Group<8>,
162    Arg<"FunctionName">, Required, Completion<"Symbol">,
163    Desc<"Set the breakpoint by function basename (C++ namespaces and arguments"
164    " will beignored).  Can be repeated multiple times to make one breakpoint "
165    "for multiplesymbols.">;
166  def breakpoint_set_source_pattern_regexp :
167    Option<"source-pattern-regexp", "p">, Group<9>, Arg<"RegularExpression">,
168    Required, Desc<"Set the breakpoint by specifying a regular expression which"
169    " is matched against the source text in a source file or files specified "
170    "with the -f can be specified more than once.  If no source files "
171    "are specified, uses the current \"default source file\".  If you want to "
172    "match against all source files, pass the \"--all-files\" option.">;
173  def breakpoint_set_all_files : Option<"all-files", "A">, Group<9>,
174    Desc<"All files are searched for source pattern matches.">;
175  def breakpoint_set_language_exception : Option<"language-exception", "E">,
176    Group<10>, Arg<"Language">, Required,
177    Desc<"Set the breakpoint on exceptions thrown by the specified language "
178    "(without options, on throw but not catch.)">;
179  def breakpoint_set_on_throw : Option<"on-throw", "w">, Group<10>,
180    Arg<"Boolean">, Desc<"Set the breakpoint on exception throW.">;
181  def breakpoint_set_on_catch : Option<"on-catch", "h">, Group<10>,
182    Arg<"Boolean">, Desc<"Set the breakpoint on exception catcH.">;
183  def breakpoint_set_language : Option<"language", "L">, GroupRange<3, 8>,
184    Arg<"Language">,
185    Desc<"Specifies the Language to use when interpreting the breakpoint's "
186    "expression (note: currently only implemented for setting breakpoints on "
187    "identifiers). If not set the target.language setting is used.">;
188  def breakpoint_set_skip_prologue : Option<"skip-prologue", "K">,
189    Arg<"Boolean">, Groups<[1,3,4,5,6,7,8,12]>,
190    Desc<"sKip the prologue if the breakpoint is at the beginning of a "
191    "function. If not set the target.skip-prologue setting is used.">;
192  def breakpoint_set_breakpoint_name : Option<"breakpoint-name", "N">,
193    Arg<"BreakpointName">,
194    Desc<"Adds this to the list of names for this breakpoint.">;
195  def breakpoint_set_address_slide : Option<"address-slide", "R">,
196    Arg<"Address">, Groups<[1,3,4,5,6,7,8,12]>,
197    Desc<"Add the specified offset to whatever address(es) the breakpoint "
198    "resolves to. At present this applies the offset directly as given, and "
199    "doesn't try to align it to instruction boundaries.">;
200  def breakpoint_set_move_to_nearest_code : Option<"move-to-nearest-code", "m">,
201    Groups<[1,9,12]>, Arg<"Boolean">,
202    Desc<"Move breakpoints to nearest code. If not set the "
203    "target.move-to-nearest-codesetting is used.">;
204  def breakpoint_set_file_colon_line : Option<"joint-specifier", "y">, Group<12>, Arg<"FileLineColumn">,
205    Required, Completion<"SourceFile">,
206    Desc<"A specifier in the form filename:line[:column] for setting file & line breakpoints.">;
207  /* Don't add this option till it actually does something useful...
208  def breakpoint_set_exception_typename : Option<"exception-typename", "O">,
209    Arg<"TypeName">, Desc<"The breakpoint will only stop if an "
210    "exception Object of this type is thrown.  Can be repeated multiple times "
211    "to stop for multiple object types">;
212   */
213}
214
215let Command = "breakpoint clear" in {
216  def breakpoint_clear_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
217    Completion<"SourceFile">,
218    Desc<"Specify the breakpoint by source location in this particular file.">;
219  def breakpoint_clear_line : Option<"line", "l">, Group<1>, Arg<"LineNum">,
220    Required,
221    Desc<"Specify the breakpoint by source location at this particular line.">;
222}
223
224let Command = "breakpoint delete" in {
225  def breakpoint_delete_force : Option<"force", "f">, Group<1>,
226    Desc<"Delete all breakpoints without querying for confirmation.">;
227  def breakpoint_delete_dummy_breakpoints : Option<"dummy-breakpoints", "D">,
228    Group<1>, Desc<"Delete Dummy breakpoints - i.e. breakpoints set before a "
229    "file is provided, which prime new targets.">;
230  def breakpoint_delete_disabled : Option<"disabled", "d">, Group<1>,
231    Desc<"Delete all breakpoints which are currently disabled.  When using the disabled option "
232    "any breakpoints listed on the command line are EXCLUDED from deletion.">;
233}
234
235let Command = "breakpoint name" in {
236  def breakpoint_name_name : Option<"name", "N">, Group<1>,
237    Arg<"BreakpointName">, Desc<"Specifies a breakpoint name to use.">;
238  def breakpoint_name_breakpoint_id : Option<"breakpoint-id", "B">, Group<2>,
239    Arg<"BreakpointID">, Desc<"Specify a breakpoint ID to use.">;
240  def breakpoint_name_dummy_breakpoints : Option<"dummy-breakpoints", "D">,
241    Group<3>, Desc<"Operate on Dummy breakpoints - i.e. breakpoints set before "
242    "a file is provided, which prime new targets.">;
243  def breakpoint_name_help_string : Option<"help-string", "H">, Group<4>,
244    Arg<"None">, Desc<"A help string describing the purpose of this name.">;
245}
246
247let Command = "breakpoint access" in {
248  def breakpoint_access_allow_list : Option<"allow-list", "L">, Group<1>,
249    Arg<"Boolean">, Desc<"Determines whether the breakpoint will show up in "
250    "break list if not referred to explicitly.">;
251  def breakpoint_access_allow_disable : Option<"allow-disable", "A">, Group<2>,
252    Arg<"Boolean">, Desc<"Determines whether the breakpoint can be disabled by "
253    "name or when all breakpoints are disabled.">;
254  def breakpoint_access_allow_delete : Option<"allow-delete", "D">, Group<3>,
255    Arg<"Boolean">, Desc<"Determines whether the breakpoint can be deleted by "
256    "name or when all breakpoints are deleted.">;
257}
258
259let Command = "breakpoint read" in {
260  def breakpoint_read_file : Option<"file", "f">, Arg<"Filename">, Required,
261    Completion<"DiskFile">,
262    Desc<"The file from which to read the breakpoints.">;
263  def breakpoint_read_breakpoint_name : Option<"breakpoint-name", "N">,
264    Arg<"BreakpointName">, Desc<"Only read in breakpoints with this name.">;
265}
266
267let Command = "breakpoint write" in {
268  def breakpoint_write_file : Option<"file", "f">, Arg<"Filename">, Required,
269    Completion<"DiskFile">,
270    Desc<"The file into which to write the breakpoints.">;
271  def breakpoint_write_append : Option<"append", "a">,
272    Desc<"Append to saved breakpoints file if it exists.">;
273}
274
275let Command = "breakpoint command add" in {
276  def breakpoint_add_one_liner : Option<"one-liner", "o">, Group<1>,
277    Arg<"OneLiner">, Desc<"Specify a one-line breakpoint command inline. Be "
278    "sure to surround it with quotes.">;
279  def breakpoint_add_stop_on_error : Option<"stop-on-error", "e">,
280    Arg<"Boolean">, Desc<"Specify whether breakpoint command execution should "
281    "terminate on error.">;
282  def breakpoint_add_script_type : Option<"script-type", "s">,
283    EnumArg<"None", "ScriptOptionEnum()">,
284    Desc<"Specify the language for the commands - if none is specified, the "
285    "lldb command interpreter will be used.">;
286  def breakpoint_add_dummy_breakpoints : Option<"dummy-breakpoints", "D">,
287    Desc<"Sets Dummy breakpoints - i.e. breakpoints set before a file is "
288    "provided, which prime new targets.">;
289}
290
291let Command = "breakpoint command delete" in {
292  def breakpoint_command_delete_dummy_breakpoints :
293    Option<"dummy-breakpoints", "D">, Group<1>,
294    Desc<"Delete commands from Dummy breakpoints - i.e. breakpoints set before "
295    "a file is provided, which prime new targets.">;
296}
297
298let Command = "disassemble" in {
299  def disassemble_options_bytes : Option<"bytes", "b">,
300    Desc<"Show opcode bytes when disassembling.">;
301  def disassemble_options_context : Option<"context", "C">, Arg<"NumLines">,
302    Desc<"Number of context lines of source to show.">;
303  def disassemble_options_mixed : Option<"mixed", "m">,
304    Desc<"Enable mixed source and assembly display.">;
305  def disassemble_options_raw : Option<"raw", "r">,
306    Desc<"Print raw disassembly with no symbol information.">;
307  def disassemble_options_plugin : Option<"plugin", "P">, Arg<"Plugin">,
308    Desc<"Name of the disassembler plugin you want to use.">;
309  def disassemble_options_flavor : Option<"flavor", "F">,
310    Arg<"DisassemblyFlavor">, Desc<"Name of the disassembly flavor you want to "
311    "use. Currently the only valid options are default, and for Intel "
312    "architectures, att and intel.">;
313  def disassemble_options_arch : Option<"arch", "A">, Arg<"Architecture">,
314    Desc<"Specify the architecture to use from cross disassembly.">;
315  def disassemble_options_start_address : Option<"start-address", "s">,
316    Groups<[1,2]>, Arg<"AddressOrExpression">, Required,
317    Desc<"Address at which to start disassembling.">;
318  def disassemble_options_end_address : Option<"end-address", "e">, Group<1>,
319    Arg<"AddressOrExpression">, Desc<"Address at which to end disassembling.">;
320  def disassemble_options_count : Option<"count", "c">, Groups<[2,3,4,5,7]>,
321    Arg<"NumLines">, Desc<"Number of instructions to display.">;
322  def disassemble_options_name : Option<"name", "n">, Group<3>,
323    Arg<"FunctionName">, Completion<"Symbol">,
324    Desc<"Disassemble entire contents of the given function name.">;
325  def disassemble_options_frame : Option<"frame", "f">, Group<4>,
326    Desc<"Disassemble from the start of the current frame's function.">;
327  def disassemble_options_pc : Option<"pc", "p">, Group<5>,
328    Desc<"Disassemble around the current pc.">;
329  def disassemble_options_line : Option<"line", "l">, Group<6>,
330    Desc<"Disassemble the current frame's current source line instructions if "
331    "there is debug line table information, else disassemble around the pc.">;
332  def disassemble_options_address : Option<"address", "a">, Group<7>,
333    Arg<"AddressOrExpression">,
334    Desc<"Disassemble function containing this address.">;
335  def disassemble_options_force : Option<"force", "\\x01">, Groups<[2,3,4,5,7]>,
336    Desc<"Force dissasembly of large functions.">;
337}
338
339let Command = "expression" in {
340  def expression_options_all_threads : Option<"all-threads", "a">,
341    Groups<[1,2]>, Arg<"Boolean">, Desc<"Should we run all threads if the "
342    "execution doesn't complete on one thread.">;
343  def expression_options_ignore_breakpoints : Option<"ignore-breakpoints", "i">,
344    Groups<[1,2]>, Arg<"Boolean">,
345    Desc<"Ignore breakpoint hits while running expressions">;
346  def expression_options_timeout : Option<"timeout", "t">, Groups<[1,2]>,
347    Arg<"UnsignedInteger">,
348    Desc<"Timeout value (in microseconds) for running the expression.">;
349  def expression_options_unwind_on_error : Option<"unwind-on-error", "u">,
350    Groups<[1,2]>, Arg<"Boolean">,
351    Desc<"Clean up program state if the expression causes a crash, or raises a "
352    "signal. Note, unlike gdb hitting a breakpoint is controlled by another "
353    "option (-i).">;
354  def expression_options_debug : Option<"debug", "g">, Groups<[1,2]>,
355    Desc<"When specified, debug the JIT code by setting a breakpoint on the "
356    "first instruction and forcing breakpoints to not be ignored (-i0) and no "
357    "unwinding to happen on error (-u0).">;
358  def expression_options_language : Option<"language", "l">, Groups<[1,2]>,
359    Arg<"Language">, Desc<"Specifies the Language to use when parsing the "
360    "expression.  If not set the target.language setting is used.">;
361  def expression_options_apply_fixits : Option<"apply-fixits", "X">,
362    Groups<[1,2]>, Arg<"Language">, Desc<"If true, simple fix-it hints will be "
363    "automatically applied to the expression.">;
364  def expression_options_description_verbosity :
365    Option<"description-verbosity", "v">, Group<1>,
366    OptionalEnumArg<"DescriptionVerbosity", "DescriptionVerbosityTypes()">,
367    Desc<"How verbose should the output of this expression be, if the object "
368    "description is asked for.">;
369  def expression_options_top_level : Option<"top-level", "p">, Groups<[1,2]>,
370    Desc<"Interpret the expression as a complete translation unit, without "
371    "injecting it into the local context.  Allows declaration of persistent, "
372    "top-level entities without a $ prefix.">;
373  def expression_options_allow_jit : Option<"allow-jit", "j">, Groups<[1,2]>,
374    Arg<"Boolean">,
375    Desc<"Controls whether the expression can fall back to being JITted if it's "
376    "not supported by the interpreter (defaults to true).">;
377}
378
379let Command = "frame diag" in {
380  def frame_diag_register : Option<"register", "r">, Group<1>,
381    Arg<"RegisterName">, Desc<"A register to diagnose.">;
382  def frame_diag_address : Option<"address", "a">, Group<1>, Arg<"Address">,
383    Desc<"An address to diagnose.">;
384  def frame_diag_offset : Option<"offset", "o">, Group<1>, Arg<"Offset">,
385    Desc<"An optional offset.  Requires --register.">;
386}
387
388let Command = "frame select" in {
389  def frame_select_relative : Option<"relative", "r">, Group<1>, Arg<"Offset">,
390    Desc<"A relative frame index offset from the current frame index.">;
391}
392
393let Command = "frame recognizer add" in {
394  def frame_recognizer_shlib : Option<"shlib", "s">, Arg<"ShlibName">,
395    Completion<"Module">,
396    Desc<"Name of the module or shared library that this recognizer applies "
397    "to.">;
398  def frame_recognizer_function : Option<"function", "n">, Arg<"Name">,
399    Completion<"Symbol">,
400    Desc<"Name of the function that this recognizer applies to. "
401         "Can be specified more than once except if -x|--regex is provided.">;
402  def frame_recognizer_python_class : Option<"python-class", "l">, Group<2>,
403    Arg<"PythonClass">,
404    Desc<"Give the name of a Python class to use for this frame recognizer.">;
405  def frame_recognizer_regex : Option<"regex", "x">,
406    Desc<"Function name and module name are actually regular expressions.">;
407}
408
409let Command = "history" in {
410  def history_count : Option<"count", "c">, Group<1>, Arg<"UnsignedInteger">,
411    Desc<"How many history commands to print.">;
412  def history_start_index : Option<"start-index", "s">, Group<1>,
413    Arg<"UnsignedInteger">, Desc<"Index at which to start printing history "
414    "commands (or end to mean tail mode).">;
415  def history_end_index : Option<"end-index", "e">, Group<1>,
416    Arg<"UnsignedInteger">,
417    Desc<"Index at which to stop printing history commands.">;
418  def history_clear : Option<"clear", "C">, Group<2>,
419    Desc<"Clears the current command history.">;
420}
421
422let Command = "log" in {
423  def log_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
424    Desc<"Set the destination file to log to.">;
425  def log_threadsafe : Option<"threadsafe", "t">, Group<1>,
426    Desc<"Enable thread safe logging to avoid interweaved log lines.">;
427  def log_verbose : Option<"verbose", "v">, Group<1>,
428    Desc<"Enable verbose logging.">;
429  def log_sequence : Option<"sequence", "s">, Group<1>,
430    Desc<"Prepend all log lines with an increasing integer sequence id.">;
431  def log_timestamp : Option<"timestamp", "T">, Group<1>,
432    Desc<"Prepend all log lines with a timestamp.">;
433  def log_pid_tid : Option<"pid-tid", "p">, Group<1>,
434    Desc<"Prepend all log lines with the process and thread ID that generates "
435    "the log line.">;
436  def log_thread_name : Option<"thread-name", "n">, Group<1>,
437    Desc<"Prepend all log lines with the thread name for the thread that "
438    "generates the log line.">;
439
440  def log_stack : Option<"stack", "S">, Group<1>,
441    Desc<"Append a stack backtrace to each log line.">;
442  def log_append : Option<"append", "a">, Group<1>,
443    Desc<"Append to the log file instead of overwriting.">;
444  def log_file_function : Option<"file-function", "F">, Group<1>,
445    Desc<"Prepend the names of files and function that generate the logs.">;
446}
447
448let Command = "reproducer dump" in {
449  def reproducer_provider : Option<"provider", "p">, Group<1>,
450    EnumArg<"None", "ReproducerProviderType()">,
451    Required, Desc<"The reproducer provider to dump.">;
452  def reproducer_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
453    Desc<"The reproducer path. If a reproducer is replayed and no path is "
454    "provided, that reproducer is dumped.">;
455}
456
457let Command = "reproducer verify" in {
458  def reproducer_verify_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
459    Desc<"The reproducer path. If a reproducer is replayed and no path is "
460    "provided, that reproducer is dumped.">;
461}
462
463let Command = "reproducer xcrash" in {
464  def reproducer_signal : Option<"signal", "s">, Group<1>,
465    EnumArg<"None", "ReproducerSignalType()">,
466    Required, Desc<"The signal to crash the debugger.">;
467}
468
469let Command = "memory read" in {
470  def memory_read_num_per_line : Option<"num-per-line", "l">, Group<1>,
471    Arg<"NumberPerLine">, Desc<"The number of items per line to display.">;
472  def memory_read_binary : Option<"binary", "b">, Group<2>,
473    Desc<"If true, memory will be saved as binary. If false, the memory is "
474    "saved save as an ASCII dump that uses the format, size, count and number "
475    "per line settings.">;
476  def memory_read_type : Option<"type", "t">, Groups<[3,4]>, Arg<"Name">,
477    Required, Desc<"The name of a type to view memory as.">;
478  def memory_read_language : Option<"language", "x">, Group<4>, Arg<"Language">,
479    Desc<"The language of the type to view memory as.">;
480  def memory_read_offset : Option<"offset", "E">, Group<3>, Arg<"Count">,
481    Desc<"How many elements of the specified type to skip before starting to "
482    "display data.">;
483  def memory_read_force : Option<"force", "r">, Groups<[1,2,3]>,
484    Desc<"Necessary if reading over target.max-memory-read-size bytes.">;
485}
486
487let Command = "memory find" in {
488  def memory_find_expression : Option<"expression", "e">, Group<1>,
489    Arg<"Expression">, Required,
490    Desc<"Evaluate an expression to obtain a byte pattern.">;
491  def memory_find_string : Option<"string", "s">, Group<2>, Arg<"Name">,
492    Required, Desc<"Use text to find a byte pattern.">;
493  def memory_find_count : Option<"count", "c">, Arg<"Count">,
494    Desc<"How many times to perform the search.">;
495  def memory_find_dump_offset : Option<"dump-offset", "o">, Arg<"Offset">,
496    Desc<"When dumping memory for a match, an offset from the match location to"
497    " start dumping from.">;
498}
499
500let Command = "memory write" in {
501  def memory_write_infile : Option<"infile", "i">, Group<1>, Arg<"Filename">,
502    Required, Desc<"Write memory using the contents of a file.">;
503  def memory_write_offset : Option<"offset", "o">, Group<1>, Arg<"Offset">,
504    Desc<"Start writing bytes from an offset within the input file.">;
505}
506
507let Command = "register read" in {
508  def register_read_alternate : Option<"alternate", "A">,
509    Desc<"Display register names using the alternate register name if there "
510    "is one.">;
511  def register_read_set : Option<"set", "s">, Group<1>, Arg<"Index">,
512    Desc<"Specify which register sets to dump by index.">;
513  def register_read_all : Option<"all", "a">, Group<2>,
514    Desc<"Show all register sets.">;
515}
516
517let Command = "source" in {
518  def source_stop_on_error : Option<"stop-on-error", "e">, Arg<"Boolean">,
519    Desc<"If true, stop executing commands on error.">;
520  def source_stop_on_continue : Option<"stop-on-continue", "c">, Arg<"Boolean">,
521    Desc<"If true, stop executing commands on continue.">;
522  def source_silent_run : Option<"silent-run", "s">, Arg<"Boolean">,
523    Desc<"If true don't echo commands while executing.">;
524}
525
526let Command = "alias" in {
527  def alias_help : Option<"help", "h">, Arg<"HelpText">,
528    Desc<"Help text for this command">;
529  def alias_long_help : Option<"long-help", "H">, Arg<"HelpText">,
530    Desc<"Long help text for this command">;
531}
532
533let Command = "regex" in {
534  def regex_help : Option<"help", "h">, Group<1>, Arg<"None">,
535    Desc<"The help text to display for this command.">;
536  def regex_syntax : Option<"syntax", "s">, Group<1>, Arg<"None">,
537    Desc<"A syntax string showing the typical usage syntax.">;
538}
539
540let Command = "permissions" in {
541  def permissions_permissions_value : Option<"permissions-value", "v">,
542    Arg<"PermissionsNumber">,
543    Desc<"Give out the numeric value for permissions (e.g. 757)">;
544  def permissions_permissions_string : Option<"permissions-string", "s">,
545    Arg<"PermissionsString">,
546    Desc<"Give out the string value for permissions (e.g. rwxr-xr--).">;
547  def permissions_user_read : Option<"user-read", "r">,
548    Desc<"Allow user to read.">;
549  def permissions_user_write : Option<"user-write", "w">,
550    Desc<"Allow user to write.">;
551  def permissions_user_exec : Option<"user-exec", "x">,
552    Desc<"Allow user to execute.">;
553  def permissions_group_read : Option<"group-read", "R">,
554    Desc<"Allow group to read.">;
555  def permissions_group_write : Option<"group-write", "W">,
556    Desc<"Allow group to write.">;
557  def permissions_group_exec : Option<"group-exec", "X">,
558    Desc<"Allow group to execute.">;
559  def permissions_world_read : Option<"world-read", "d">,
560    Desc<"Allow world to read.">;
561  def permissions_world_write : Option<"world-write", "t">,
562    Desc<"Allow world to write.">;
563  def permissions_world_exec : Option<"world-exec", "e">,
564    Desc<"Allow world to execute.">;
565}
566
567let Command = "platform fread" in {
568  def platform_fread_offset : Option<"offset", "o">, Group<1>, Arg<"Index">,
569    Desc<"Offset into the file at which to start reading.">;
570  def platform_fread_count : Option<"count", "c">, Group<1>, Arg<"Count">,
571    Desc<"Number of bytes to read from the file.">;
572}
573
574let Command = "platform fwrite" in {
575  def platform_fwrite_offset : Option<"offset", "o">, Group<1>, Arg<"Index">,
576    Desc<"Offset into the file at which to start reading.">;
577  def platform_fwrite_data : Option<"data", "d">, Group<1>, Arg<"Value">,
578    Desc<"Text to write to the file.">;
579}
580
581let Command = "platform process list" in {
582  def platform_process_list_pid : Option<"pid", "p">, Group<1>, Arg<"Pid">,
583    Desc<"List the process info for a specific process ID.">;
584  def platform_process_list_name : Option<"name", "n">, Group<2>,
585    Arg<"ProcessName">, Required,
586    Desc<"Find processes with executable basenames that match a string.">;
587  def platform_process_list_ends_with : Option<"ends-with", "e">, Group<3>,
588  Arg<"ProcessName">, Required,
589    Desc<"Find processes with executable basenames that end with a string.">;
590  def platform_process_list_starts_with : Option<"starts-with", "s">, Group<4>,
591    Arg<"ProcessName">, Required,
592    Desc<"Find processes with executable basenames that start with a string.">;
593  def platform_process_list_contains : Option<"contains", "c">, Group<5>,
594    Arg<"ProcessName">, Required,
595    Desc<"Find processes with executable basenames that contain a string.">;
596  def platform_process_list_regex : Option<"regex", "r">, Group<6>,
597    Arg<"RegularExpression">, Required,
598    Desc<"Find processes with executable basenames that match a regular "
599    "expression.">;
600  def platform_process_list_parent : Option<"parent", "P">, GroupRange<2, 6>,
601    Arg<"Pid">, Desc<"Find processes that have a matching parent process ID.">;
602  def platform_process_list_uid : Option<"uid", "u">, GroupRange<2, 6>,
603    Arg<"UnsignedInteger">, Validator<"&posix_validator">,
604    Desc<"Find processes that have a matching user ID.">;
605  def platform_process_list_euid : Option<"euid", "U">, GroupRange<2, 6>,
606    Arg<"UnsignedInteger">, Validator<"&posix_validator">,
607    Desc<"Find processes that have a matching effective user ID.">;
608  def platform_process_list_gid : Option<"gid", "g">, GroupRange<2, 6>,
609    Arg<"UnsignedInteger">, Validator<"&posix_validator">,
610    Desc<"Find processes that have a matching group ID.">;
611  def platform_process_list_egid : Option<"egid", "G">, GroupRange<2, 6>,
612    Arg<"UnsignedInteger">, Validator<"&posix_validator">,
613    Desc<"Find processes that have a matching effective group ID.">;
614  def platform_process_list_arch : Option<"arch", "a">, GroupRange<2, 6>,
615    Arg<"Architecture">,
616    Desc<"Find processes that have a matching architecture.">;
617  def platform_process_list_show_args : Option<"show-args", "A">,
618    GroupRange<1, 6>,
619    Desc<"Show process arguments instead of the process executable basename.">;
620  def platform_process_list_all_users: Option<"all-users", "x">,
621    GroupRange<1,6>,
622    Desc<"Show processes matching all user IDs.">;
623  def platform_process_list_verbose : Option<"verbose", "v">, GroupRange<1, 6>,
624    Desc<"Enable verbose output.">;
625}
626
627let Command = "platform process attach" in {
628  def platform_process_attach_plugin : Option<"plugin", "P">, Arg<"Plugin">,
629    Desc<"Name of the process plugin you want to use.">;
630  def platform_process_attach_pid : Option<"pid", "p">, Group<1>, Arg<"Pid">,
631    Desc<"The process ID of an existing process to attach to.">;
632  def platform_process_attach_name : Option<"name", "n">, Group<2>,
633    Arg<"ProcessName">, Desc<"The name of the process to attach to.">;
634  def platform_process_attach_waitfor : Option<"waitfor", "w">, Group<2>,
635    Desc<"Wait for the process with <process-name> to launch.">;
636}
637
638let Command = "platform shell" in {
639  def platform_shell_host : Option<"host", "h">,
640    Desc<"Run the commands on the host shell when enabled.">;
641  def platform_shell_timeout : Option<"timeout", "t">, Arg<"Value">,
642    Desc<"Seconds to wait for the remote host to finish running the command.">;
643  def platform_shell_interpreter : Option<"shell", "s">, Arg<"Path">,
644    Desc<"Shell interpreter path. This is the binary used to run the command.">;
645}
646
647let Command = "process launch" in {
648  def process_launch_stop_at_entry : Option<"stop-at-entry", "s">,
649    Desc<"Stop at the entry point of the program when launching a process.">;
650  def process_launch_disable_aslr : Option<"disable-aslr", "A">, Arg<"Boolean">,
651    Desc<"Set whether to disable address space layout randomization when launching a process.">;
652  def process_launch_plugin : Option<"plugin", "P">, Arg<"Plugin">,
653    Desc<"Name of the process plugin you want to use.">;
654  def process_launch_working_dir : Option<"working-dir", "w">, Arg<"DirectoryName">,
655    Desc<"Set the current working directory to <path> when running the inferior.">;
656  def process_launch_arch : Option<"arch", "a">, Arg<"Architecture">,
657    Desc<"Set the architecture for the process to launch when ambiguous.">;
658  def process_launch_environment : Option<"environment", "v">,
659    Arg<"None">, Desc<"Specify an environment variable name/value string "
660    "(--environment NAME=VALUE). Can be specified multiple times for subsequent "
661    "environment entries.">;
662  def process_launch_shell : Option<"shell", "c">, GroupRange<1,3>,
663    OptionalArg<"Filename">, Desc<"Run the process in a shell (not supported on all platforms).">;
664  def process_launch_stdin : Option<"stdin", "i">, Group<1>,
665    Arg<"Filename">, Desc<"Redirect stdin for the process to <filename>.">;
666  def process_launch_stdout : Option<"stdout", "o">, Group<1>,
667    Arg<"Filename">, Desc<"Redirect stdout for the process to <filename>.">;
668  def process_launch_stderr : Option<"stderr", "e">, Group<1>,
669    Arg<"Filename">, Desc<"Redirect stderr for the process to <filename>.">;
670  def process_launch_tty : Option<"tty", "t">, Group<2>,
671    Desc<"Start the process in a terminal (not supported on all platforms).">;
672  def process_launch_no_stdio : Option<"no-stdio", "n">, Group<3>,
673    Desc<"Do not set up for terminal I/O to go to running process.">;
674  def process_launch_shell_expand_args : Option<"shell-expand-args", "X">, Group<4>,
675    Arg<"Boolean">, Desc<"Set whether to shell expand arguments to the process when launching.">;
676}
677
678let Command = "process attach" in {
679  def process_attach_continue : Option<"continue", "c">,
680    Desc<"Immediately continue the process once attached.">;
681  def process_attach_plugin : Option<"plugin", "P">, Arg<"Plugin">,
682    Desc<"Name of the process plugin you want to use.">;
683  def process_attach_pid : Option<"pid", "p">, Group<1>, Arg<"Pid">,
684    Desc<"The process ID of an existing process to attach to.">;
685  def process_attach_name : Option<"name", "n">, Group<2>, Arg<"ProcessName">,
686    Desc<"The name of the process to attach to.">;
687  def process_attach_include_existing : Option<"include-existing", "i">,
688    Group<2>, Desc<"Include existing processes when doing attach -w.">;
689  def process_attach_waitfor : Option<"waitfor", "w">, Group<2>,
690    Desc<"Wait for the process with <process-name> to launch.">;
691}
692
693let Command = "process continue" in {
694  def process_continue_ignore_count : Option<"ignore-count", "i">,
695    Arg<"UnsignedInteger">, Desc<"Ignore <N> crossings of the breakpoint (if it"
696    " exists) for the currently selected thread.">;
697}
698
699let Command = "process detach" in {
700  def process_detach_keep_stopped : Option<"keep-stopped", "s">, Group<1>,
701    Arg<"Boolean">, Desc<"Whether or not the process should be kept stopped on"
702    " detach (if possible).">;
703}
704
705let Command = "process connect" in {
706  def process_connect_plugin : Option<"plugin", "p">, Arg<"Plugin">,
707    Desc<"Name of the process plugin you want to use.">;
708}
709
710let Command = "process load" in {
711  def process_load_install : Option<"install", "i">, OptionalArg<"Path">,
712    Desc<"Install the shared library to the target. If specified without an "
713    "argument then the library will installed in the current working "
714    "directory.">;
715}
716
717let Command = "process handle" in {
718  def process_handle_stop : Option<"stop", "s">, Group<1>, Arg<"Boolean">,
719    Desc<"Whether or not the process should be stopped if the signal is "
720    "received.">;
721  def process_handle_notify : Option<"notify", "n">, Group<1>, Arg<"Boolean">,
722    Desc<"Whether or not the debugger should notify the user if the signal is "
723    "received.">;
724  def process_handle_pass : Option<"pass", "p">, Group<1>, Arg<"Boolean">,
725    Desc<"Whether or not the signal should be passed to the process.">;
726}
727
728let Command = "process status" in {
729  def process_status_verbose : Option<"verbose", "v">, Group<1>,
730    Desc<"Show verbose process status including extended crash information.">;
731}
732
733let Command = "script import" in {
734  def script_import_allow_reload : Option<"allow-reload", "r">, Group<1>,
735    Desc<"Allow the script to be loaded even if it was already loaded before. "
736    "This argument exists for backwards compatibility, but reloading is always "
737    "allowed, whether you specify it or not.">;
738  def relative_to_command_file : Option<"relative-to-command-file", "c">,
739    Group<1>, Desc<"Resolve non-absolute paths relative to the location of the "
740    "current command file. This argument can only be used when the command is "
741    "being sourced from a file.">;
742}
743
744let Command = "script add" in {
745  def script_add_function : Option<"function", "f">, Group<1>,
746    Arg<"PythonFunction">,
747    Desc<"Name of the Python function to bind to this command name.">;
748  def script_add_class : Option<"class", "c">, Group<2>, Arg<"PythonClass">,
749  Desc<"Name of the Python class to bind to this command name.">;
750  def script_add_help : Option<"help", "h">, Group<1>, Arg<"HelpText">,
751  Desc<"The help text to display for this command.">;
752  def script_add_synchronicity : Option<"synchronicity", "s">,
753    EnumArg<"ScriptedCommandSynchronicity", "ScriptSynchroType()">,
754    Desc<"Set the synchronicity of this command's executions with regard to "
755    "LLDB event system.">;
756}
757
758let Command = "script" in {
759  def script_language : Option<"language", "l">,
760    EnumArg<"ScriptLang", "ScriptOptionEnum()">, Desc<"Specify the scripting "
761    " language. If none is specific the default scripting language is used.">;
762}
763
764let Command = "source info" in {
765  def source_info_count : Option<"count", "c">, Arg<"Count">,
766    Desc<"The number of line entries to display.">;
767  def source_info_shlib : Option<"shlib", "s">, Groups<[1,2]>, Arg<"ShlibName">,
768    Completion<"Module">, Desc<"Look up the source in the given module or "
769    "shared library (can be specified more than once).">;
770  def source_info_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
771    Completion<"SourceFile">, Desc<"The file from which to display source.">;
772  def source_info_line : Option<"line", "l">, Group<1>, Arg<"LineNum">,
773    Desc<"The line number at which to start the displaying lines.">;
774  def source_info_end_line : Option<"end-line", "e">, Group<1>, Arg<"LineNum">,
775    Desc<"The line number at which to stop displaying lines.">;
776  def source_info_name : Option<"name", "n">, Group<2>, Arg<"Symbol">,
777    Completion<"Symbol">,
778    Desc<"The name of a function whose source to display.">;
779  def source_info_address : Option<"address", "a">, Group<3>,
780    Arg<"AddressOrExpression">, Desc<"Lookup the address and display the source"
781    " information for the corresponding file and line.">;
782}
783
784let Command = "source list" in {
785  def source_list_count : Option<"count", "c">, Arg<"Count">,
786    Desc<"The number of source lines to display.">;
787  def source_list_shlib : Option<"shlib", "s">, Groups<[1,2,5]>, Arg<"ShlibName">,
788    Completion<"Module">,
789    Desc<"Look up the source file in the given shared library.">;
790  def source_list_show_breakpoints : Option<"show-breakpoints", "b">,
791    Desc<"Show the line table locations from the debug information that "
792    "indicate valid places to set source level breakpoints.">;
793  def source_list_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
794    Completion<"SourceFile">, Desc<"The file from which to display source.">;
795  def source_list_line : Option<"line", "l">, Group<1>, Arg<"LineNum">,
796    Desc<"The line number at which to start the display source.">;
797  def source_list_name : Option<"name", "n">, Group<2>, Arg<"Symbol">,
798    Completion<"Symbol">,
799    Desc<"The name of a function whose source to display.">;
800  def source_list_address : Option<"address", "a">, Group<3>,
801    Arg<"AddressOrExpression">, Desc<"Lookup the address and display the source"
802    " information for the corresponding file and line.">;
803  def source_list_reverse : Option<"reverse", "r">, Group<4>, Desc<"Reverse the"
804    " listing to look backwards from the last displayed block of source.">;
805  def source_list_file_colon_line : Option<"joint-specifier", "y">, Group<5>,
806    Arg<"FileLineColumn">, Completion<"SourceFile">,
807    Desc<"A specifier in the form filename:line[:column] from which to display"
808         " source.">;
809}
810
811let Command = "target dependents" in {
812  def dependents_no_dependents : Option<"no-dependents", "d">, Group<1>,
813    OptionalEnumArg<"Value", "OptionEnumValues(g_dependents_enumaration)">,
814    Desc<"Whether or not to load dependents when creating a target. If the "
815         "option is not specified, the value is implicitly 'default'. If the "
816         "option is specified but without a value, the value is implicitly "
817         "'true'.">;
818}
819
820let Command = "target modules dump" in {
821  def target_modules_dump_verbose : Option<"verbose", "v">,
822    Desc<"Enable verbose dump.">;
823}
824
825let Command = "target modules list" in {
826  def target_modules_list_address : Option<"address", "a">, Group<1>,
827    Arg<"AddressOrExpression">, Desc<"Display the image at this address.">;
828  def target_modules_list_arch : Option<"arch", "A">, Group<1>,
829    OptionalArg<"Width">, Desc<"Display the architecture when listing images.">;
830  def target_modules_list_triple : Option<"triple", "t">, Group<1>,
831    OptionalArg<"Width">, Desc<"Display the triple when listing images.">;
832  def target_modules_list_header : Option<"header", "h">, Group<1>,
833    Desc<"Display the image base address as a load address if debugging, a file"
834    " address otherwise.">;
835  def target_modules_list_offset : Option<"offset", "o">, Group<1>,
836    Desc<"Display the image load address offset from the base file address "
837    "(the slide amount).">;
838  def target_modules_list_uuid : Option<"uuid", "u">, Group<1>,
839    Desc<"Display the UUID when listing images.">;
840  def target_modules_list_fullpath : Option<"fullpath", "f">, Group<1>,
841    OptionalArg<"Width">,
842    Desc<"Display the fullpath to the image object file.">;
843  def target_modules_list_directory : Option<"directory", "d">, Group<1>,
844    OptionalArg<"Width">, Desc<"Display the directory with optional width for "
845    "the image object file.">;
846  def target_modules_list_basename : Option<"basename", "b">, Group<1>,
847    OptionalArg<"Width">, Desc<"Display the basename with optional width for "
848    "the image object file.">;
849  def target_modules_list_symfile : Option<"symfile", "s">, Group<1>,
850    OptionalArg<"Width">, Desc<"Display the fullpath to the image symbol file "
851    "with optional width.">;
852  def target_modules_list_symfile_unique : Option<"symfile-unique", "S">,
853    Group<1>, OptionalArg<"Width">, Desc<"Display the symbol file with optional"
854    " width only if it is different from the executable object file.">;
855  def target_modules_list_mod_time : Option<"mod-time", "m">, Group<1>,
856    OptionalArg<"Width">, Desc<"Display the modification time with optional "
857    "width of the module.">;
858  def target_modules_list_ref_count : Option<"ref-count", "r">, Group<1>,
859    OptionalArg<"Width">, Desc<"Display the reference count if the module is "
860    "still in the shared module cache.">;
861  def target_modules_list_pointer : Option<"pointer", "p">, Group<1>,
862    OptionalArg<"None">, Desc<"Display the module pointer.">;
863  def target_modules_list_global : Option<"global", "g">, Group<1>,
864    Desc<"Display the modules from the global module list, not just the "
865    "current target.">;
866}
867
868let Command = "target modules show unwind" in {
869  def target_modules_show_unwind_name : Option<"name", "n">, Group<1>,
870    Arg<"FunctionName">,
871    Desc<"Show unwind instructions for a function or symbol name.">;
872  def target_modules_show_unwind_address : Option<"address", "a">, Group<2>,
873    Arg<"AddressOrExpression">, Desc<"Show unwind instructions for a function "
874    "or symbol containing an address">;
875}
876
877let Command = "target modules lookup" in {
878  def target_modules_lookup_address : Option<"address", "a">, Group<1>,
879    Arg<"AddressOrExpression">, Required, Desc<"Lookup an address in one or "
880    "more target modules.">;
881  def target_modules_lookup_offset : Option<"offset", "o">, Group<1>,
882    Arg<"Offset">, Desc<"When looking up an address subtract <offset> from any "
883    "addresses before doing the lookup.">;
884  // FIXME: re-enable regex for types when the LookupTypeInModule actually uses
885  // the regex option by adding to group 6.
886  def target_modules_lookup_regex : Option<"regex", "r">, Groups<[2,4,5]>,
887    Desc<"The <name> argument for name lookups are regular expressions.">;
888  def target_modules_lookup_symbol : Option<"symbol", "s">, Group<2>,
889    Arg<"Symbol">, Required, Desc<"Lookup a symbol by name in the symbol tables"
890    " in one or more target modules.">;
891  def target_modules_lookup_file : Option<"file", "f">, Group<3>,
892    Arg<"Filename">, Required, Desc<"Lookup a file by fullpath or basename in "
893    "one or more target modules.">;
894  def target_modules_lookup_line : Option<"line", "l">, Group<3>,
895    Arg<"LineNum">, Desc<"Lookup a line number in a file (must be used in "
896    "conjunction with --file).">;
897  def target_modules_lookup_no_inlines : Option<"no-inlines", "i">,
898    GroupRange<3,5>,
899    Desc<"Ignore inline entries (must be used in conjunction with --file or "
900    "--function).">;
901  def target_modules_lookup_function : Option<"function", "F">, Group<4>,
902    Arg<"FunctionName">, Required, Desc<"Lookup a function by name in the debug"
903    " symbols in one or more target modules.">;
904  def target_modules_lookup_name : Option<"name", "n">, Group<5>,
905    Arg<"FunctionOrSymbol">, Required, Desc<"Lookup a function or symbol by "
906    "name in one or more target modules.">;
907  def target_modules_lookup_type : Option<"type", "t">, Group<6>, Arg<"Name">,
908    Required, Desc<"Lookup a type by name in the debug symbols in one or more "
909    "target modules.">;
910  def target_modules_lookup_verbose : Option<"verbose", "v">,
911    Desc<"Enable verbose lookup information.">;
912  def target_modules_lookup_all : Option<"all", "A">, Desc<"Print all matches, "
913    "not just the best match, if a best match is available.">;
914}
915
916let Command = "target stop hook add" in {
917  def target_stop_hook_add_one_liner : Option<"one-liner", "o">, GroupRange<1,3>,
918    Arg<"OneLiner">, Desc<"Add a command for the stop hook.  Can be specified "
919    "more than once, and commands will be run in the order they appear.">;
920  def target_stop_hook_add_shlib : Option<"shlib", "s">, Arg<"ShlibName">,
921    Completion<"Module">,
922    Desc<"Set the module within which the stop-hook is to be run.">;
923  def target_stop_hook_add_thread_index : Option<"thread-index", "x">,
924    Arg<"ThreadIndex">, Desc<"The stop hook is run only for the thread whose "
925    "index matches this argument.">;
926  def target_stop_hook_add_thread_id : Option<"thread-id", "t">,
927    Arg<"ThreadID">, Desc<"The stop hook is run only for the thread whose TID "
928    "matches this argument.">;
929  def target_stop_hook_add_thread_name : Option<"thread-name", "T">,
930    Arg<"ThreadName">, Desc<"The stop hook is run only for the thread whose "
931    "thread name matches this argument.">;
932  def target_stop_hook_add_queue_name : Option<"queue-name", "q">,
933    Arg<"QueueName">, Desc<"The stop hook is run only for threads in the queue "
934    "whose name is given by this argument.">;
935  def target_stop_hook_add_file : Option<"file", "f">, Groups<[1,4]>,
936    Arg<"Filename">, Desc<"Specify the source file within which the stop-hook "
937    "is to be run.">, Completion<"SourceFile">;
938  def target_stop_hook_add_start_line : Option<"start-line", "l">, Groups<[1,4]>,
939    Arg<"LineNum">, Desc<"Set the start of the line range for which the "
940    "stop-hook is to be run.">;
941  def target_stop_hook_add_end_line : Option<"end-line", "e">, Groups<[1,4]>,
942    Arg<"LineNum">, Desc<"Set the end of the line range for which the stop-hook"
943    " is to be run.">;
944  def target_stop_hook_add_classname : Option<"classname", "c">, Groups<[2,5]>,
945    Arg<"ClassName">,
946    Desc<"Specify the class within which the stop-hook is to be run.">;
947  def target_stop_hook_add_name : Option<"name", "n">, Groups<[3,6]>,
948    Arg<"FunctionName">, Desc<"Set the function name within which the stop hook"
949    " will be run.">, Completion<"Symbol">;
950  def target_stop_hook_add_auto_continue : Option<"auto-continue", "G">,
951    Arg<"Boolean">, Desc<"The breakpoint will auto-continue after running its"
952    " commands.">;
953}
954
955let Command = "thread backtrace" in {
956  def thread_backtrace_count : Option<"count", "c">, Group<1>, Arg<"Count">,
957  Desc<"How many frames to display (-1 for all)">;
958  def thread_backtrace_start : Option<"start", "s">, Group<1>,
959  Arg<"FrameIndex">, Desc<"Frame in which to start the backtrace">;
960  def thread_backtrace_extended : Option<"extended", "e">, Group<1>,
961  Arg<"Boolean">, Desc<"Show the extended backtrace, if available">;
962}
963
964let Command = "thread step scope" in {
965  def thread_step_scope_step_in_avoids_no_debug :
966    Option<"step-in-avoids-no-debug", "a">, Group<1>, Arg<"Boolean">,
967    Desc<"A boolean value that sets whether stepping into functions will step "
968    "over functions with no debug information.">;
969  def thread_step_scope_step_out_avoids_no_debug :
970    Option<"step-out-avoids-no-debug", "A">, Group<1>, Arg<"Boolean">,
971    Desc<"A boolean value, if true stepping out of functions will continue to"
972    " step out till it hits a function with debug information.">;
973  def thread_step_scope_count : Option<"count", "c">, Group<1>, Arg<"Count">,
974    Desc<"How many times to perform the stepping operation - currently only "
975    "supported for step-inst and next-inst.">;
976  def thread_step_scope_end_linenumber : Option<"end-linenumber", "e">,
977    Group<1>, Arg<"LineNum">, Desc<"The line at which to stop stepping - "
978      "defaults to the next line and only supported for step-in and step-over."
979      "  You can also pass the string 'block' to step to the end of the current"
980      " block.  This is particularly use  in conjunction with --step-target to"
981      " step through a complex calling sequence.">;
982  def thread_step_scope_run_mode : Option<"run-mode", "m">, Group<1>,
983    EnumArg<"RunMode", "TriRunningModes()">, Desc<"Determine how to run other "
984    "threads while stepping the current thread.">;
985  def thread_step_scope_step_over_regexp : Option<"step-over-regexp", "r">,
986    Group<1>, Arg<"RegularExpression">, Desc<"A regular expression that defines "
987    "function names to not to stop at when stepping in.">;
988  def thread_step_scope_step_in_target : Option<"step-in-target", "t">,
989    Group<1>, Arg<"FunctionName">, Desc<"The name of the directly called "
990    "function step in should stop at when stepping into.">;
991}
992
993let Command = "thread until" in {
994  def thread_until_frame : Option<"frame", "f">, Group<1>, Arg<"FrameIndex">,
995    Desc<"Frame index for until operation - defaults to 0">;
996  def thread_until_thread : Option<"thread", "t">, Group<1>, Arg<"ThreadIndex">,
997    Desc<"Thread index for the thread for until operation">;
998  def thread_until_run_mode : Option<"run-mode", "m">, Group<1>,
999    EnumArg<"RunMode", "DuoRunningModes()">, Desc<"Determine how to run other "
1000    "threads while stepping this one">;
1001  def thread_until_address : Option<"address", "a">, Group<1>,
1002    Arg<"AddressOrExpression">, Desc<"Run until we reach the specified address, "
1003    "or leave the function - can be specified multiple times.">;
1004}
1005
1006let Command = "thread info" in {
1007  def thread_info_json : Option<"json", "j">, Desc<"Display the thread info in"
1008    " JSON format.">;
1009  def thread_info_stop_info : Option<"stop-info", "s">, Desc<"Display the "
1010    "extended stop info in JSON format.">;
1011}
1012
1013let Command = "thread return" in {
1014  def thread_return_from_expression : Option<"from-expression", "x">,
1015    Desc<"Return from the innermost expression evaluation.">;
1016}
1017
1018let Command = "thread jump" in {
1019  def thread_jump_file : Option<"file", "f">, Group<1>, Arg<"Filename">,
1020    Completion<"SourceFile">, Desc<"Specifies the source file to jump to.">;
1021  def thread_jump_line : Option<"line", "l">, Group<1>, Arg<"LineNum">,
1022    Required, Desc<"Specifies the line number to jump to.">;
1023  def thread_jump_by : Option<"by", "b">, Group<2>, Arg<"Offset">, Required,
1024    Desc<"Jumps by a relative line offset from the current line.">;
1025  def thread_jump_address : Option<"address", "a">, Group<3>,
1026    Arg<"AddressOrExpression">, Required, Desc<"Jumps to a specific address.">;
1027  def thread_jump_force : Option<"force", "r">, Groups<[1,2,3]>,
1028    Desc<"Allows the PC to leave the current function.">;
1029}
1030
1031let Command = "thread plan list" in {
1032  def thread_plan_list_verbose : Option<"verbose", "v">, Group<1>,
1033    Desc<"Display more information about the thread plans">;
1034  def thread_plan_list_internal : Option<"internal", "i">, Group<1>,
1035    Desc<"Display internal as well as user thread plans">;
1036  def thread_plan_list_thread_id : Option<"thread-id", "t">, Group<1>,
1037    Arg<"ThreadID">, Desc<"List the thread plans for this TID, can be "
1038    "specified more than once.">;
1039  def thread_plan_list_unreported : Option<"unreported", "u">, Group<1>,
1040    Desc<"Display thread plans for unreported threads">;
1041}
1042
1043let Command = "thread trace dump instructions" in {
1044  def thread_trace_dump_instructions_count : Option<"count", "c">, Group<1>,
1045    Arg<"Count">,
1046    Desc<"The number of instructions to display ending at the current position.">;
1047  def thread_trace_dump_instructions_position : Option<"position", "p">,
1048    Group<1>,
1049    Arg<"Index">,
1050    Desc<"The position to use instead of the current position of the trace.">;
1051  def thread_trace_dump_instructions_raw : Option<"raw", "r">,
1052    Group<1>,
1053    Desc<"Dump only instruction address without disassembly nor symbol information.">;
1054}
1055
1056let Command = "type summary add" in {
1057  def type_summary_add_category : Option<"category", "w">, Arg<"Name">,
1058    Desc<"Add this to the given category instead of the default one.">;
1059  def type_summary_add_cascade : Option<"cascade", "C">, Arg<"Boolean">,
1060    Desc<"If true, cascade through typedef chains.">;
1061  def type_summary_add_no_value : Option<"no-value", "v">,
1062    Desc<"Don't show the value, just show the summary, for this type.">;
1063  def type_summary_add_skip_pointers : Option<"skip-pointers", "p">,
1064    Desc<"Don't use this format for pointers-to-type objects.">;
1065  def type_summary_add_skip_references : Option<"skip-references", "r">,
1066    Desc<"Don't use this format for references-to-type objects.">;
1067  def type_summary_add_regex : Option<"regex", "x">,
1068    Desc<"Type names are actually regular expressions.">;
1069  def type_summary_add_inline_children : Option<"inline-children", "c">,
1070    Group<1>, Required,
1071    Desc<"If true, inline all child values into summary string.">;
1072  def type_summary_add_omit_names : Option<"omit-names", "O">, Group<1>,
1073    Desc<"If true, omit value names in the summary display.">;
1074  def type_summary_add_summary_string : Option<"summary-string", "s">, Group<2>,
1075    Arg<"SummaryString">, Required,
1076    Desc<"Summary string used to display text and object contents.">;
1077  def type_summary_add_python_script : Option<"python-script", "o">, Group<3>,
1078    Arg<"PythonScript">,
1079    Desc<"Give a one-liner Python script as part of the command.">;
1080  def type_summary_add_python_function : Option<"python-function", "F">,
1081    Group<3>, Arg<"PythonFunction">,
1082    Desc<"Give the name of a Python function to use for this type.">;
1083  def type_summary_add_input_python : Option<"input-python", "P">, Group<3>,
1084    Desc<"Input Python code to use for this type manually.">;
1085  def type_summary_add_expand : Option<"expand", "e">, Groups<[2,3]>,
1086    Desc<"Expand aggregate data types to show children on separate lines.">;
1087  def type_summary_add_hide_empty : Option<"hide-empty", "h">, Groups<[2,3]>,
1088    Desc<"Do not expand aggregate data types with no children.">;
1089  def type_summary_add_name : Option<"name", "n">, Groups<[2,3]>, Arg<"Name">,
1090    Desc<"A name for this summary string.">;
1091}
1092
1093let Command = "type synth add" in {
1094  def type_synth_add_cascade : Option<"cascade", "C">, Arg<"Boolean">,
1095    Desc<"If true, cascade through typedef chains.">;
1096  def type_synth_add_skip_pointers : Option<"skip-pointers", "p">,
1097    Desc<"Don't use this format for pointers-to-type objects.">;
1098  def type_synth_add_skip_references : Option<"skip-references", "r">,
1099    Desc<"Don't use this format for references-to-type objects.">;
1100  def type_synth_add_category : Option<"category", "w">, Arg<"Name">,
1101    Desc<"Add this to the given category instead of the default one.">;
1102  def type_synth_add_python_class : Option<"python-class", "l">, Group<2>,
1103    Arg<"PythonClass">,
1104    Desc<"Use this Python class to produce synthetic children.">;
1105  def type_synth_add_input_python : Option<"input-python", "P">, Group<3>,
1106    Desc<"Type Python code to generate a class that provides synthetic "
1107    "children.">;
1108  def type_synth_add_regex : Option<"regex", "x">,
1109    Desc<"Type names are actually regular expressions.">;
1110}
1111
1112let Command = "type format add" in {
1113  def type_format_add_category : Option<"category", "w">, Arg<"Name">,
1114    Desc<"Add this to the given category instead of the default one.">;
1115  def type_format_add_cascade : Option<"cascade", "C">, Arg<"Boolean">,
1116    Desc<"If true, cascade through typedef chains.">;
1117  def type_format_add_skip_pointers : Option<"skip-pointers", "p">,
1118    Desc<"Don't use this format for pointers-to-type objects.">;
1119  def type_format_add_skip_references : Option<"skip-references", "r">,
1120    Desc<"Don't use this format for references-to-type objects.">;
1121  def type_format_add_regex : Option<"regex", "x">,
1122    Desc<"Type names are actually regular expressions.">;
1123  def type_format_add_type : Option<"type", "t">, Group<2>, Arg<"Name">,
1124    Desc<"Format variables as if they were of this type.">;
1125}
1126
1127let Command = "type formatter delete" in {
1128  def type_formatter_delete_all : Option<"all", "a">, Group<1>,
1129    Desc<"Delete from every category.">;
1130  def type_formatter_delete_category : Option<"category", "w">, Group<2>,
1131    Arg<"Name">, Desc<"Delete from given category.">;
1132  def type_formatter_delete_language : Option<"language", "l">, Group<3>,
1133    Arg<"Language">, Desc<"Delete from given language's category.">;
1134}
1135
1136let Command = "type formatter clear" in {
1137  def type_formatter_clear_all : Option<"all", "a">,
1138    Desc<"Clear every category.">;
1139}
1140
1141let Command = "type formatter list" in {
1142  def type_formatter_list_category_regex : Option<"category-regex", "w">,
1143    Group<1>, Arg<"Name">, Desc<"Only show categories matching this filter.">;
1144  def type_formatter_list_language : Option<"language", "l">, Group<2>,
1145    Arg<"Language">, Desc<"Only show the category for a specific language.">;
1146}
1147
1148let Command = "type category define" in {
1149  def type_category_define_enabled : Option<"enabled", "e">,
1150    Desc<"If specified, this category will be created enabled.">;
1151  def type_category_define_language : Option<"language", "l">, Arg<"Language">,
1152    Desc<"Specify the language that this category is supported for.">;
1153}
1154
1155let Command = "type category enable" in {
1156  def type_category_enable_language : Option<"language", "l">, Arg<"Language">,
1157    Desc<"Enable the category for this language.">;
1158}
1159
1160let Command = "type category disable" in {
1161  def type_category_disable_language : Option<"language", "l">, Arg<"Language">,
1162    Desc<"Enable the category for this language.">;
1163}
1164
1165let Command = "type filter add" in {
1166  def type_filter_add_cascade : Option<"cascade", "C">, Arg<"Boolean">,
1167    Desc<"If true, cascade through typedef chains.">;
1168  def type_filter_add_skip_pointers : Option<"skip-pointers", "p">,
1169    Desc<"Don't use this format for pointers-to-type objects.">;
1170  def type_filter_add_skip_references : Option<"skip-references", "r">,
1171    Desc<"Don't use this format for references-to-type objects.">;
1172  def type_filter_add_category : Option<"category", "w">, Arg<"Name">,
1173    Desc<"Add this to the given category instead of the default one.">;
1174  def type_filter_add_child : Option<"child", "c">, Arg<"ExpressionPath">,
1175    Desc<"Include this expression path in the synthetic view.">;
1176  def type_filter_add_regex : Option<"regex", "x">,
1177    Desc<"Type names are actually regular expressions.">;
1178}
1179
1180let Command = "type lookup" in {
1181  def type_lookup_show_help : Option<"show-help", "h">,
1182    Desc<"Display available help for types">;
1183  def type_lookup_language : Option<"language", "l">, Arg<"Language">,
1184    Desc<"Which language's types should the search scope be">;
1185}
1186
1187let Command = "watchpoint list" in {
1188  def watchpoint_list_brief : Option<"brief", "b">, Group<1>, Desc<"Give a "
1189    "brief description of the watchpoint (no location info).">;
1190  def watchpoint_list_full : Option<"full", "f">, Group<2>, Desc<"Give a full "
1191    "description of the watchpoint and its locations.">;
1192  def watchpoint_list_verbose : Option<"verbose", "v">, Group<3>, Desc<"Explain "
1193    "everything we know about the watchpoint (for debugging debugger bugs).">;
1194}
1195
1196let Command = "watchpoint ignore" in {
1197  def watchpoint_ignore_ignore_count : Option<"ignore-count", "i">,
1198    Arg<"Count">, Required, Desc<"Set the number of times this watchpoint is"
1199    " skipped before stopping.">;
1200}
1201
1202let Command = "watchpoint modify" in {
1203  def watchpoint_modify_condition : Option<"condition", "c">, Arg<"Expression">,
1204    Desc<"The watchpoint stops only if this condition expression evaluates "
1205    "to true.">;
1206}
1207
1208let Command = "watchpoint command add" in {
1209  def watchpoint_command_add_one_liner : Option<"one-liner", "o">, Group<1>,
1210    Arg<"OneLiner">, Desc<"Specify a one-line watchpoint command inline. Be "
1211    "sure to surround it with quotes.">;
1212  def watchpoint_command_add_stop_on_error : Option<"stop-on-error", "e">,
1213    Arg<"Boolean">, Desc<"Specify whether watchpoint command execution should "
1214    "terminate on error.">;
1215  def watchpoint_command_add_script_type : Option<"script-type", "s">,
1216    EnumArg<"None", "ScriptOptionEnum()">, Desc<"Specify the language for the"
1217    " commands - if none is specified, the lldb command interpreter will be "
1218    "used.">;
1219  def watchpoint_command_add_python_function : Option<"python-function", "F">,
1220    Group<2>, Arg<"PythonFunction">, Desc<"Give the name of a Python function "
1221    "to run as command for this watchpoint. Be sure to give a module name if "
1222    "appropriate.">;
1223}
1224
1225let Command = "watchpoint delete" in {
1226  def watchpoint_delete_force : Option<"force", "f">, Group<1>,
1227    Desc<"Delete all watchpoints without querying for confirmation.">;
1228}
1229
1230let Command = "trace load" in {
1231  def trace_load_verbose : Option<"verbose", "v">, Group<1>,
1232    Desc<"Show verbose trace load logging for debugging the plug-in "
1233    "implementation.">;
1234}
1235
1236let Command = "trace dump" in {
1237  def trace_dump_verbose : Option<"verbose", "v">, Group<1>,
1238    Desc<"Show verbose trace information.">;
1239}
1240
1241let Command = "trace schema" in {
1242  def trace_schema_verbose : Option<"verbose", "v">, Group<1>,
1243    Desc<"Show verbose trace schema logging for debugging the plug-in.">;
1244}
1245