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