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