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