64#include "clang/Driver/CreateInvocationFromArgs.h"
65#include "clang/Frontend/CompilerInstance.h"
66#include "clang/Frontend/CompilerInvocation.h"
67#include "clang/Frontend/FrontendActions.h"
68#include "clang/Serialization/ObjectFilePCHContainerReader.h"
69#include "llvm/ADT/ScopeExit.h"
70#include "llvm/ADT/StringRef.h"
71#include "llvm/Support/FileSystem.h"
72#include "llvm/Support/FormatAdapters.h"
79 const char *prefix_cstr,
80 bool show_stopped_process_status,
Stream &strm) {
85 bool exe_valid =
false;
90 ::strcpy(exe_path,
"<none>");
92 std::string formatted_label =
"";
93 const std::string &label = target->
GetLabel();
95 formatted_label =
" (" + label +
")";
98 strm.
Printf(
"%starget #%u%s: %s", prefix_cstr ? prefix_cstr :
"", target_idx,
99 formatted_label.data(), exe_path);
101 uint32_t properties = 0;
109 strm.
Format(
"{0}platform={1}", properties++ > 0 ?
", " :
" ( ",
110 platform_sp->GetName());
113 bool show_process_status =
false;
116 StateType state = process_sp->GetState();
117 if (show_stopped_process_status)
121 strm.
Printf(
"%spid=%" PRIu64, properties++ > 0 ?
", " :
" ( ", pid);
122 strm.
Printf(
"%sstate=%s", properties++ > 0 ?
", " :
" ( ", state_cstr);
128 if (show_process_status) {
129 const bool only_threads_with_stop_reason =
true;
130 const uint32_t start_frame = 0;
131 const uint32_t num_frames = 1;
132 const uint32_t num_frames_with_source = 1;
133 const bool stop_format =
false;
134 process_sp->GetStatus(strm);
135 process_sp->GetThreadStatus(strm, only_threads_with_stop_reason,
136 start_frame, num_frames, num_frames_with_source,
142 bool show_stopped_process_status,
Stream &strm) {
147 for (uint32_t i = 0; i < num_targets; ++i) {
150 bool is_selected = target_sp.get() == selected_target_sp.get();
152 show_stopped_process_status, strm);
159#define LLDB_OPTIONS_target_dependents
160#include "CommandOptions.inc"
169 return llvm::ArrayRef(g_target_dependents_options);
177 if (option_value.empty()) {
182 const char short_option =
183 g_target_dependents_options[option_idx].short_option;
184 if (short_option ==
'd') {
187 option_value, g_target_dependents_options[option_idx].enum_values, 0,
193 "unrecognized short option '%c'", short_option);
213#pragma mark CommandObjectTargetCreate
219 interpreter,
"target create",
220 "Create a target using the argument as the main executable.",
224 "Fullpath to a core file to use for this target."),
226 "Optional name for this target.", nullptr),
229 "Fullpath to a stand alone debug "
230 "symbols file for when debug symbols "
231 "are not in the executable."),
234 "Fullpath to the file on the remote host if debugging remotely.") {
265 llvm::toString(file.takeError()));
270 if (argc == 1 || core_file || remote_file) {
279 llvm::toString(file.takeError()));
287 bool must_set_platform_path =
false;
292 llvm::StringRef arch_cstr =
m_arch_option.GetArchitectureName();
294 debugger, file_path, arch_cstr,
303 const llvm::StringRef label =
304 m_label.GetOptionValue().GetCurrentValueAsRef();
305 if (!label.empty()) {
306 if (
auto E = target_sp->SetLabel(label))
313 llvm::scope_exit on_error(
315 target_list.DeleteTarget(target_sp);
322 PlatformSP platform_sp = target_sp->GetPlatform();
326 file_spec.
SetFile(file_path, FileSpec::Style::native);
331 if (platform_sp && platform_sp->IsHost() &&
341 if (!platform_sp->GetFileExists(remote_file)) {
342 Status err = platform_sp->PutFile(file_spec, remote_file);
356 Status err = platform_sp->GetFile(remote_file, file_spec);
370 if (platform_sp->IsHost()) {
371 result.
AppendError(
"Supply a local file, not a remote file, "
372 "when debugging on the host.");
375 if (platform_sp->IsConnected() && !platform_sp->GetFileExists(remote_file)) {
376 result.
AppendError(
"remote --> local transfer without local "
377 "path is not implemented yet");
384 target_sp->SetProcessLaunchInfo(launch_info);
388 result.
AppendError(
"no platform found for target");
393 if (symfile || remote_file) {
394 ModuleSP module_sp(target_sp->GetExecutableModule());
397 module_sp->SetSymbolFileFileSpec(symfile);
399 std::string remote_path = remote_file.
GetPath();
400 target_sp->SetArg0(remote_path.c_str());
401 module_sp->SetPlatformFileSpec(remote_file);
406 if (must_set_platform_path) {
409 target_sp->GetOrCreateModule(main_module_spec,
true );
411 module_sp->SetPlatformFileSpec(remote_file);
417 target_sp->AppendExecutableSearchPaths(core_file_dir);
419 ProcessSP process_sp(target_sp->CreateProcess(
420 GetDebugger().GetListener(), llvm::StringRef(), &core_file,
false));
427 target_sp->GetStatistics().GetLoadCoreTime());
428 error = process_sp->LoadCore();
436 "Core file '{0}' ({1}) was loaded.\n", core_file.
GetPath(),
437 target_sp->GetArchitecture().GetArchitectureName());
447 "Current executable set to '{0}' ({1}).",
449 target_sp->GetArchitecture().GetArchitectureName());
455 "argument, or use the --core option",
471#pragma mark CommandObjectTargetList
477 interpreter,
"target list",
478 "List all current targets in the current debug session.", nullptr) {
487 bool show_stopped_process_status =
false;
489 show_stopped_process_status, strm) == 0) {
496#pragma mark CommandObjectTargetSelect
502 interpreter,
"target select",
503 "Select a target as the current target by target index.", nullptr) {
516 if (llvm::to_integer(target_identifier, target_idx)) {
517 if (target_idx < num_targets) {
520 bool show_stopped_process_status =
false;
524 if (num_targets > 0) {
526 "index %u is out of range, valid target indexes are 0 - %u",
527 target_idx, num_targets - 1);
530 "index %u is out of range since there are no active targets",
535 for (
size_t i = 0; i < num_targets; i++) {
537 const std::string &label = target_sp->GetLabel();
538 if (!label.empty() && label == target_identifier) {
548 bool show_stopped_process_status =
false;
558 "'target select' takes a single argument: a target index\n");
563#pragma mark CommandObjectTargetDelete
569 "Delete one or more targets by target index.",
575 "Perform extra cleanup to minimize memory consumption after "
576 "deleting the target. "
577 "By default, LLDB will keep in memory any modules previously "
578 "loaded by the target as well "
579 "as all of its debug info. Specifying --clean will unload all of "
580 "these shared modules and "
581 "cause them to be reparsed again the next time the target is run",
596 std::vector<TargetSP> delete_target_list;
603 }
else if (argc > 0) {
606 if (num_targets == 0) {
611 for (
auto &entry : args.
entries()) {
613 if (entry.ref().getAsInteger(0, target_idx)) {
618 if (target_idx < num_targets) {
621 delete_target_list.push_back(target_sp);
627 "target indexes are 0 - %u",
628 target_idx, num_targets - 1);
631 "target index %u is out of range, the only valid index is 0",
642 delete_target_list.push_back(target_sp);
645 const size_t num_targets_to_delete = delete_target_list.size();
646 for (
size_t idx = 0; idx < num_targets_to_delete; ++idx) {
647 target_sp = delete_target_list[idx];
649 target_sp->Destroy();
654 const bool mandatory =
true;
658 (uint32_t)num_targets_to_delete);
671 interpreter,
"target show-launch-environment",
672 "Shows the environment being passed to the process when launched, "
673 "taking info account 3 settings: target.env-vars, "
674 "target.inherit-env and target.unset-env-vars.",
675 nullptr, eCommandRequiresTarget) {}
684 std::vector<Environment::value_type *> env_vector;
685 env_vector.reserve(env.size());
687 env_vector.push_back(&KV);
688 std::sort(env_vector.begin(), env_vector.end(),
689 [](Environment::value_type *a, Environment::value_type *b) {
690 return a->first() < b->first();
694 for (
auto &KV : env_vector)
695 strm.
Format(
"{0}={1}\n", KV->first(), KV->second);
701#pragma mark CommandObjectTargetVariable
710 "Read global variables for the current target, "
711 "before or while running a process.",
712 nullptr, eCommandRequiresTarget),
717 "A basename or fullpath to a file that contains "
718 "global variables. This option can be "
719 "specified multiple times."),
723 "A basename or fullpath to a shared library to use in the search "
725 "variables. This option can be specified multiple times.") {
744 const char *root_name) {
747 if (!valobj_sp->GetTargetSP()->GetDisplayRuntimeSupportValues() &&
748 valobj_sp->IsRuntimeSupportValue())
751 switch (var_sp->GetScope()) {
782 bool show_fullpaths =
false;
783 bool show_module =
true;
784 if (var_sp->DumpDeclaration(&s, show_fullpaths, show_module))
794 if (llvm::Error
error = valobj_sp->Dump(s, options))
800 size_t old_size = variable_list.
GetSize();
805 return variable_list.
GetSize() - old_size;
816 if (variable_list.
Empty())
820 s.
Format(
"Global variables for {0} in {1}:\n",
823 s.
Printf(
"Global variables for %s\n",
824 sc.
module_sp->GetFileSpec().GetPath().c_str());
853 bool use_var_name =
false;
858 "error: invalid regular expression: '%s'\n", arg.c_str());
864 matches = variable_list.
GetSize();
867 arg.c_str(),
m_exe_ctx.GetBestExecutionContextScope(),
869 matches = variable_list.
GetSize();
877 for (uint32_t global_idx = 0; global_idx < matches; ++global_idx) {
884 m_exe_ctx.GetBestExecutionContextScope(), var_sp);
888 use_var_name ? var_sp->GetName().GetCString()
900 const size_t num_compile_units = compile_units.
GetSize();
901 const size_t num_shlibs = shlibs.
GetSize();
902 if (num_compile_units == 0 && num_shlibs == 0) {
903 bool success =
false;
910 const bool can_create =
true;
913 if (comp_unit_varlist_sp) {
914 size_t count = comp_unit_varlist_sp->GetSize();
927 "no global variables in current compile unit: {0}\n",
933 result.
AppendError(
"'target variable' takes one or more global "
934 "variable names as arguments\n");
939 if (num_shlibs > 0) {
940 for (
size_t shlib_idx = 0; shlib_idx < num_shlibs; ++shlib_idx) {
947 if (num_compile_units > 0) {
948 for (
size_t cu_idx = 0; cu_idx < num_compile_units; ++cu_idx)
949 module_sp->FindCompileUnits(
959 "target doesn't contain the specified shared library: %s",
960 module_file.
GetPath().c_str());
966 for (
size_t cu_idx = 0; cu_idx < num_compile_units; ++cu_idx)
973 const bool can_create =
true;
975 sc.comp_unit->GetVariableList(can_create));
976 if (comp_unit_varlist_sp)
979 }
else if (sc.module_sp) {
982 llvm::StringRef(
"."));
984 sc.module_sp->FindGlobalVariables(all_globals_regex,
UINT32_MAX,
1006#pragma mark CommandObjectTargetModulesSearchPathsAdd
1012 "Add new image search paths substitution pairs to "
1013 "the current target.",
1014 nullptr, eCommandRequiresTarget) {
1033 arg.push_back(old_prefix_arg);
1034 arg.push_back(new_prefix_arg);
1046 result.
AppendError(
"add requires an even number of arguments\n");
1048 for (
size_t i = 0; i < argc; i += 2) {
1052 if (from[0] && to[0]) {
1054 "target modules search path adding ImageSearchPath "
1055 "pair: '%s' -> '%s'",
1057 bool last_pair = ((argc - i) == 2);
1059 from, to, last_pair);
1063 result.
AppendError(
"<path-prefix> can't be empty\n");
1065 result.
AppendError(
"<new-path-prefix> can't be empty\n");
1072#pragma mark CommandObjectTargetModulesSearchPathsClear
1078 "Clear all current image search path substitution "
1079 "pairs from the current target.",
1080 "target modules search-paths clear",
1081 eCommandRequiresTarget) {}
1094#pragma mark CommandObjectTargetModulesSearchPathsInsert
1100 "Insert a new image search path substitution pair "
1101 "into the current target at the specified index.",
1102 nullptr, eCommandRequiresTarget) {
1114 arg1.push_back(index_arg);
1130 arg2.push_back(old_prefix_arg);
1131 arg2.push_back(new_prefix_arg);
1148 const size_t num = list.
GetSize();
1150 for (
size_t i = 0; i < num; ++i) {
1154 strm << old_path <<
" -> " << new_path;
1164 if (argc >= 3 && argc & 1) {
1165 uint32_t insert_idx;
1169 "<index> parameter is not an integer: '%s'",
1178 for (uint32_t i = 0; i < argc; i += 2, ++insert_idx) {
1182 if (from[0] && to[0]) {
1183 bool last_pair = ((argc - i) == 2);
1189 result.
AppendError(
"<path-prefix> can't be empty\n");
1191 result.
AppendError(
"<new-path-prefix> can't be empty\n");
1196 result.
AppendError(
"insert requires at least three arguments\n");
1201#pragma mark CommandObjectTargetModulesSearchPathsList
1207 "List all current image search path substitution "
1208 "pairs in the current target.",
1209 "target modules search-paths list",
1210 eCommandRequiresTarget) {}
1222#pragma mark CommandObjectTargetModulesSearchPathsQuery
1228 interpreter,
"target modules search-paths query",
1229 "Transform a path using the first applicable image search path.",
1230 nullptr, eCommandRequiresTarget) {
1240 result.
AppendError(
"query requires one argument\n");
1257 bool full_triple, uint32_t width) {
1262 module->GetArchitecture().DumpTriple(arch_strm.AsRawOstream());
1265 std::string arch_str = std::string(arch_strm.
GetString());
1268 strm.
Printf(
"%-*s", width, arch_str.c_str());
1276 module->GetUUID().Dump(strm);
1285 uint32_t num_matches = 0;
1288 num_matches =
module->ResolveSymbolContextsForFileSpec(
1289 file_spec, 0, false, eSymbolContextCompUnit, sc_list);
1291 bool first_module =
true;
1296 strm <<
"Line table for " << sc.comp_unit->GetPrimaryFile() <<
" in `"
1297 <<
module->GetFileSpec().GetFilename() << "\n";
1298 LineTable *line_table = sc.comp_unit->GetLineTable();
1304 strm <<
"No line table";
1306 first_module =
false;
1314 if (file_spec_ptr) {
1316 std::string fullpath = file_spec_ptr->
GetPath();
1317 strm.
Printf(
"%-*s", width, fullpath.c_str());
1326 strm.
Printf(
"%-*s", width,
"");
1331 if (file_spec_ptr) {
1340 strm.
Printf(
"%-*s", width,
"");
1345 if (file_spec_ptr) {
1354 strm.
Printf(
"%-*s", width,
"");
1358 std::lock_guard<std::recursive_mutex> guard(module_list.
GetMutex());
1359 const size_t num_modules = module_list.
GetSize();
1360 if (num_modules == 0)
1363 size_t num_dumped = 0;
1364 strm.
Format(
"Dumping headers for {0} module(s).\n", num_modules);
1368 if (num_dumped++ > 0) {
1372 ObjectFile *objfile = module_sp->GetObjectFile();
1374 objfile->
Dump(&strm);
1376 strm.
Format(
"No object file for module: {0:F}\n",
1377 module_sp->GetFileSpec());
1392 sort_order, name_preference);
1398 SectionList *section_list =
module->GetSectionList();
1400 strm.
Printf(
"Sections for '%s' (%s):\n",
1413 symbol_file->Dump(strm);
1421 Module *module,
bool errors_only,
1422 bool load_all_debug_info) {
1426 if (symbol_file->GetSeparateDebugInfo(d, errors_only,
1427 load_all_debug_info)) {
1429 std::make_shared<StructuredData::Dictionary>(std::move(d)));
1442 "------------------ --- -----------------------------------------");
1451 strm.
Printf(
"0x%16.16" PRIx64
" ", dwo_id);
1453 strm.
Printf(
"0x???????????????? ");
1455 llvm::StringRef
error;
1457 strm <<
"E " <<
error;
1459 llvm::StringRef resolved_dwo_path;
1461 resolved_dwo_path)) {
1462 strm <<
" " << resolved_dwo_path;
1463 if (resolved_dwo_path.ends_with(
".dwp")) {
1464 llvm::StringRef dwo_name;
1466 strm <<
"(" << dwo_name <<
")";
1479 strm.
PutCString(
"------------------ --- ---------------------");
1486 uint32_t oso_mod_time;
1488 strm.
Printf(
"0x%16.16" PRIx32
" ", oso_mod_time);
1490 llvm::StringRef
error;
1492 strm <<
"E " <<
error;
1494 llvm::StringRef oso_path;
1496 strm <<
" " << oso_path;
1505 bool verbose,
bool all_ranges,
Stream &strm,
1506 std::optional<Stream::HighlightSettings> settings = std::nullopt) {
1508 strm.
Indent(
" Address: ");
1513 strm.
Indent(
" Summary: ");
1529 Module *module, uint32_t resolve_mask,
1531 bool verbose,
bool all_ranges) {
1540 else if (so_addr.
GetModule().get() != module)
1549 DumpAddress(exe_scope, so_addr, verbose, all_ranges, strm);
1558 const char *name,
bool name_is_regex,
1559 bool verbose,
bool all_ranges) {
1563 Symtab *symtab =
module->GetSymtab();
1569 std::vector<uint32_t> match_indexes;
1571 uint32_t num_matches = 0;
1572 if (name_is_regex) {
1581 if (num_matches > 0) {
1583 strm.
Printf(
"%u symbols match %s'%s' in ", num_matches,
1584 name_is_regex ?
"the regular expression " :
"", name);
1591 for (uint32_t i = 0; i < num_matches; ++i) {
1598 use_color && name_is_regex
1599 ? std::optional<Stream::HighlightSettings>{settings}
1607 use_color && name_is_regex
1608 ? std::optional<Stream::HighlightSettings>{settings}
1629 std::optional<Stream::HighlightSettings> settings = std::nullopt) {
1631 bool first_module =
true;
1637 if (sc.line_entry.IsValid())
1638 addr = sc.line_entry.range.GetBaseAddress();
1639 else if (sc.block && sc.block->GetContainingInlinedBlock())
1640 sc.block->GetContainingInlinedBlock()->GetStartAddress(addr);
1642 addr = sc.GetFunctionOrSymbolAddress();
1644 DumpAddress(exe_scope, addr, verbose, all_ranges, strm, settings);
1645 first_module =
false;
1652 const char *name,
bool name_is_regex,
1654 bool verbose,
bool all_ranges) {
1655 if (module && name && name[0]) {
1657 size_t num_matches = 0;
1658 if (name_is_regex) {
1660 module->FindFunctions(function_name_regex, options, sc_list);
1663 module->FindFunctions(function_name, CompilerDeclContext(),
1664 eFunctionNameTypeAuto, options, sc_list);
1666 num_matches = sc_list.
GetSize();
1669 strm.
Printf(
"%" PRIu64
" match%s found in ", (uint64_t)num_matches,
1670 num_matches > 1 ?
"es" :
"");
1675 strm, sc_list, verbose, all_ranges);
1684 Module *module,
const char *name_cstr,
1685 bool name_is_regex) {
1686 if (module && name_cstr && name_cstr[0]) {
1689 module->FindTypes(query, results);
1694 sc.
module_sp =
module->shared_from_this();
1698 if (type_list.
Empty())
1701 const uint64_t num_matches = type_list.
GetSize();
1704 strm.
Printf(
"%" PRIu64
" match%s found in ", num_matches,
1705 num_matches > 1 ?
"es" :
"");
1713 type_sp->GetFullCompilerType();
1716 TypeSP typedef_type_sp(type_sp);
1717 TypeSP typedefed_type_sp(typedef_type_sp->GetTypedefType());
1718 while (typedefed_type_sp) {
1720 strm.
Printf(
" typedef '%s': ",
1721 typedef_type_sp->GetName().GetCString());
1722 typedefed_type_sp->GetFullCompilerType();
1725 typedef_type_sp = typedefed_type_sp;
1726 typedefed_type_sp = typedef_type_sp->GetTypedefType();
1737 const char *name_cstr,
bool name_is_regex) {
1740 module.FindTypes(query, results);
1743 sc.
module_sp =
module.shared_from_this();
1745 if (type_list.
Empty())
1757 type_sp->GetFullCompilerType();
1760 TypeSP typedef_type_sp(type_sp);
1761 TypeSP typedefed_type_sp(typedef_type_sp->GetTypedefType());
1762 while (typedefed_type_sp) {
1764 strm.
Printf(
" typedef '%s': ",
1765 typedef_type_sp->GetName().GetCString());
1766 typedefed_type_sp->GetFullCompilerType();
1769 typedef_type_sp = typedefed_type_sp;
1770 typedefed_type_sp = typedef_type_sp->GetTypedefType();
1780 uint32_t line,
bool check_inlines,
1781 bool verbose,
bool all_ranges) {
1782 if (module && file_spec) {
1784 const uint32_t num_matches =
module->ResolveSymbolContextsForFileSpec(
1785 file_spec, line, check_inlines, eSymbolContextEverything, sc_list);
1786 if (num_matches > 0) {
1788 strm.
Printf(
"%u match%s found in ", num_matches,
1789 num_matches > 1 ?
"es" :
"");
1792 strm.
Printf(
":%u", line);
1798 strm, sc_list, verbose, all_ranges);
1807 bool check_global_list) {
1808 FileSpec module_file_spec(module_name);
1811 const size_t initial_size = module_list.
GetSize();
1813 if (check_global_list) {
1815 std::lock_guard<std::recursive_mutex> guard(
1819 for (
size_t image_idx = 0; image_idx < num_modules; ++image_idx) {
1824 module_sp =
module->shared_from_this();
1832 const size_t num_matches = module_list.
GetSize();
1836 if (num_matches == 0) {
1845 return module_list.
GetSize() - initial_size;
1848#pragma mark CommandObjectTargetModulesModuleAutoComplete
1875#pragma mark CommandObjectTargetModulesSourceFileAutoComplete
1885 const char *syntax, uint32_t flags)
1900#pragma mark CommandObjectTargetModulesDumpObjfile
1907 interpreter,
"target modules dump objfile",
1908 "Dump the object file headers from one or more target modules.",
1909 nullptr, eCommandRequiresTarget) {}
1917 size_t num_dumped = 0;
1922 if (num_dumped == 0) {
1923 result.
AppendError(
"the target has no associated executable images");
1928 const char *arg_cstr;
1929 for (
int arg_idx = 0;
1932 size_t num_matched =
1934 if (num_matched == 0) {
1936 "unable to find an image that matches '{0}'", arg_cstr);
1944 if (num_dumped > 0) {
1947 result.
AppendError(
"no matching executable images found");
1952#define LLDB_OPTIONS_target_modules_dump_symtab
1953#include "CommandOptions.inc"
1960 interpreter,
"target modules dump symtab",
1961 "Dump the symbol table from one or more target modules.", nullptr,
1962 eCommandRequiresTarget) {}
1979 switch (short_option) {
1992 llvm_unreachable(
"Unimplemented option");
2003 return llvm::ArrayRef(g_target_modules_dump_symtab_options);
2013 uint32_t num_dumped = 0;
2021 std::lock_guard<std::recursive_mutex> guard(module_list.
GetMutex());
2022 const size_t num_modules = module_list.
GetSize();
2023 if (num_modules > 0) {
2025 "Dumping symbol table for {0} modules.\n", num_modules);
2027 if (num_dumped > 0) {
2032 "Interrupted in dump all symtabs with {0} "
2033 "of {1} dumped.", num_dumped, num_modules))
2038 module_sp.get(),
m_options.m_sort_order,
2042 result.
AppendError(
"the target has no associated executable images");
2047 const char *arg_cstr;
2048 for (
int arg_idx = 0;
2052 const size_t num_matches =
2054 if (num_matches > 0) {
2057 if (num_dumped > 0) {
2062 "Interrupted in dump symtab list with {0} of {1} dumped.",
2063 num_dumped, num_matches))
2068 module_sp.get(),
m_options.m_sort_order,
2074 "unable to find an image that matches '{0}'", arg_cstr);
2081 result.
AppendError(
"no matching executable images found");
2088#pragma mark CommandObjectTargetModulesDumpSections
2097 interpreter,
"target modules dump sections",
2098 "Dump the sections from one or more target modules.",
2100 nullptr, eCommandRequiresTarget) {}
2107 uint32_t num_dumped = 0;
2112 if (num_modules == 0) {
2113 result.
AppendError(
"the target has no associated executable images");
2119 for (
size_t image_idx = 0; image_idx < num_modules; ++image_idx) {
2121 "Interrupted in dump all sections with {0} of {1} dumped",
2122 image_idx, num_modules))
2132 const char *arg_cstr;
2133 for (
int arg_idx = 0;
2137 const size_t num_matches =
2139 if (num_matches > 0) {
2140 for (
size_t i = 0; i < num_matches; ++i) {
2142 "Interrupted in dump section list with {0} of {1} dumped.",
2155 std::lock_guard<std::recursive_mutex> guard(
2159 "unable to find an image that matches '{0}'", arg_cstr);
2167 result.
AppendError(
"no matching executable images found");
2176 interpreter,
"target modules dump pcm-info",
2177 "Dump information about the given clang module (pcm).") {
2196 result.
AppendError(
"file must have a .pcm extension");
2205 const char *clang_args[] = {
"clang", pcm_path};
2206 clang::CompilerInstance compiler(clang::createInvocation(clang_args));
2207 compiler.setVirtualFileSystem(
2209 compiler.createDiagnostics();
2213 std::shared_ptr<llvm::raw_ostream> Out(
2215 clang::DumpModuleInfoAction dump_module_info(Out);
2217 compiler.getPCHContainerOperations()->registerReader(
2218 std::make_unique<clang::ObjectFilePCHContainerReader>());
2220 if (compiler.ExecuteAction(dump_module_info))
2225#pragma mark CommandObjectTargetModulesDumpClangAST
2234 interpreter,
"target modules dump ast",
2235 "Dump the clang ast for a given module's symbol file.",
2236 "target modules dump ast [--filter <name>] [<file1> ...]",
2237 eCommandRequiresTarget),
2239 "Dump only the decls whose names contain the specified filter "
2258 const size_t num_modules = module_list.
GetSize();
2259 if (num_modules == 0) {
2260 result.
AppendError(
"the target has no associated executable images");
2264 llvm::StringRef filter =
m_filter.GetOptionValue().GetCurrentValueAsRef();
2273 if (
SymbolFile *sf = module_sp->GetSymbolFile())
2284 const size_t num_matches =
2286 if (num_matches == 0) {
2288 std::lock_guard<std::recursive_mutex> guard(
2292 "unable to find an image that matches '{0}'", arg.c_str());
2296 for (
size_t i = 0; i < num_matches; ++i) {
2298 "Interrupted in dump clang ast list with {0} of {1} dumped.",
2312#pragma mark CommandObjectTargetModulesDumpSymfile
2321 interpreter,
"target modules dump symfile",
2322 "Dump the debug symbol file for one or more target modules.",
2324 nullptr, eCommandRequiresTarget) {}
2331 uint32_t num_dumped = 0;
2336 std::lock_guard<std::recursive_mutex> guard(target_modules.
GetMutex());
2337 const size_t num_modules = target_modules.
GetSize();
2338 if (num_modules == 0) {
2339 result.
AppendError(
"the target has no associated executable images");
2343 "Dumping debug symbols for {0} modules.\n", num_modules);
2346 "debug symbols with {0} of {1} modules dumped",
2347 num_dumped, num_modules))
2355 const char *arg_cstr;
2356 for (
int arg_idx = 0;
2360 const size_t num_matches =
2362 if (num_matches > 0) {
2363 for (
size_t i = 0; i < num_matches; ++i) {
2365 "of {1} requested modules",
2376 "unable to find an image that matches '{0}'", arg_cstr);
2383 result.
AppendError(
"no matching executable images found");
2388#pragma mark CommandObjectTargetModulesDumpLineTable
2389#define LLDB_OPTIONS_target_modules_dump
2390#include "CommandOptions.inc"
2399 interpreter,
"target modules dump line-table",
2400 "Dump the line table for one or more compilation units.", nullptr,
2401 eCommandRequiresTarget) {}
2410 uint32_t total_num_dumped = 0;
2413 result.
AppendError(
"file option must be specified");
2417 const char *arg_cstr;
2418 for (
int arg_idx = 0;
2424 std::lock_guard<std::recursive_mutex> guard(target_modules.
GetMutex());
2425 size_t num_modules = target_modules.
GetSize();
2426 if (num_modules > 0) {
2427 uint32_t num_dumped = 0;
2430 "Interrupted in dump all line tables with "
2431 "{0} of {1} dumped", num_dumped,
2442 if (num_dumped == 0)
2446 total_num_dumped += num_dumped;
2451 if (total_num_dumped > 0)
2454 result.
AppendError(
"no source filenames matched any command arguments");
2464 assert(option_idx == 0 &&
"We only have one option.");
2475 return llvm::ArrayRef(g_target_modules_dump_options);
2484#pragma mark CommandObjectTargetModulesDumpSeparateDebugInfoFiles
2485#define LLDB_OPTIONS_target_modules_dump_separate_debug_info
2486#include "CommandOptions.inc"
2496 interpreter,
"target modules dump separate-debug-info",
2497 "List the separate debug info symbol files for one or more target "
2499 nullptr, eCommandRequiresTarget) {}
2516 switch (short_option) {
2522 m_json.SetCurrentValue(
true);
2523 m_json.SetOptionWasSet();
2530 llvm_unreachable(
"Unimplemented option");
2542 return llvm::ArrayRef(g_target_modules_dump_separate_debug_info_options);
2553 uint32_t num_dumped = 0;
2559 std::lock_guard<std::recursive_mutex> guard(target_modules.
GetMutex());
2560 const size_t num_modules = target_modules.
GetSize();
2561 if (num_modules == 0) {
2562 result.
AppendError(
"the target has no associated executable images");
2568 "Interrupted in dumping all "
2569 "separate debug info with {0} of {1} modules dumped",
2570 num_dumped, num_modules))
2581 const char *arg_cstr;
2582 for (
int arg_idx = 0;
2586 const size_t num_matches =
2588 if (num_matches > 0) {
2589 for (
size_t i = 0; i < num_matches; ++i) {
2591 "Interrupted dumping {0} "
2592 "of {1} requested modules",
2603 "unable to find an image that matches '{0}'", arg_cstr);
2607 if (num_dumped > 0) {
2612 separate_debug_info_lists_by_module.
Dump(strm,
2616 separate_debug_info_lists_by_module.
ForEach(
2626 if (!separate_debug_info_list) {
2630 llvm::StringRef type;
2631 llvm::StringRef symfile;
2638 "separate-debug-info-files", files))) {
2642 strm <<
"Symbol file: " << symfile;
2644 strm <<
"Type: \"" << type <<
"\"";
2646 if (type ==
"dwo") {
2648 }
else if (type ==
"oso") {
2652 "found unsupported debug info type '{0}'", type);
2659 result.
AppendError(
"no matching executable images found");
2666#pragma mark CommandObjectTargetModulesDump
2675 interpreter,
"target modules dump",
2676 "Commands for dumping information about one or more target "
2678 "target modules dump "
2679 "[objfile|symtab|sections|ast|symfile|line-table|pcm-info|separate-"
2681 "[<file1> <file2> ...]") {
2717 "Add a new module to the current target's modules.",
2718 "target modules add [<module>]",
2719 eCommandRequiresTarget),
2722 "Fullpath to a stand alone debug "
2723 "symbols file for when debug symbols "
2724 "are not in the executable.") {
2768 "Unable to create the executable or symbol file with "
2769 "UUID %s with path %s and symbol file %s",
2774 "Unable to create the executable or symbol file with "
2775 "UUID %s with path %s",
2781 "or symbol file with UUID %s",
2790 "Unable to locate the executable or symbol file with UUID %s",
2797 "one or more executable image paths must be specified");
2801 for (
auto &entry : args.
entries()) {
2802 if (entry.ref().empty())
2820 const char *error_cstr =
error.AsCString();
2832 std::string resolved_path = file_spec.
GetPath();
2833 if (resolved_path != entry.ref()) {
2835 "invalid module path '%s' with resolved path '%s'",
2836 entry.ref().str().c_str(), resolved_path.c_str());
2859 interpreter,
"target modules load",
2860 "Set the load addresses for one or more sections in a target "
2862 "target modules load [--file <module> --uuid <uuid>] <sect-name> "
2863 "<address> [<sect-name> <address> ....]",
2864 eCommandRequiresTarget),
2866 "Fullpath or basename for module to load.",
""),
2868 "Write file contents to the memory.", false, true),
2870 "Set PC to the entry point."
2871 " Only applicable with '--load' option.",
2874 "Set the load address for all sections to be the "
2875 "virtual address in the file plus the offset.",
2893 const bool load =
m_load_option.GetOptionValue().GetCurrentValue();
2894 const bool set_pc =
m_pc_option.GetOptionValue().GetCurrentValue();
2898 bool search_using_module_spec =
false;
2905 if (module_list.
GetSize() == 1) {
2906 search_using_module_spec =
true;
2914 search_using_module_spec =
true;
2915 const char *arg_cstr =
m_file_option.GetOptionValue().GetCurrentValue();
2916 const bool use_global_module_list =
true;
2919 &target, arg_cstr, module_list, use_global_module_list);
2920 if (num_matches == 1) {
2923 }
else if (num_matches > 1) {
2924 search_using_module_spec =
false;
2928 search_using_module_spec =
false;
2935 search_using_module_spec =
true;
2940 if (search_using_module_spec) {
2943 const size_t num_matches = matching_modules.
GetSize();
2946 if (num_matches == 1) {
2949 ObjectFile *objfile =
module->GetObjectFile();
2951 SectionList *section_list =
module->GetSectionList();
2953 bool changed =
false;
2958 const bool slide_is_offset =
true;
2959 module->SetLoadAddress(target, slide, slide_is_offset,
2962 result.
AppendError(
"one or more section name + load "
2963 "address pair must be specified");
2968 result.
AppendError(
"The \"--slide <offset>\" option can't "
2969 "be used in conjunction with setting "
2970 "section load addresses.\n");
2974 for (
size_t i = 0; i < argc; i += 2) {
2977 if (sect_name && load_addr_cstr) {
2980 if (llvm::to_integer(load_addr_cstr, load_addr)) {
2984 if (section_sp->IsThreadSpecific()) {
2986 "thread specific sections are not yet "
2987 "supported (section '%s')",
2995 "section '{0}' loaded at {1:x}", sect_name,
3000 "matches the section "
3007 "invalid load address string '%s'", load_addr_cstr);
3012 result.
AppendError(
"section names must be followed by "
3013 "a load address.\n");
3015 result.
AppendError(
"one or more section name + load "
3016 "address pair must be specified.\n");
3035 if (set_pc && !file_entry.
IsValid()) {
3036 result.
AppendError(
"No entry address in object file");
3039 std::vector<ObjectFile::LoadableData> loadables(
3041 if (loadables.size() == 0) {
3045 Status error = process->WriteObjectFile(std::move(loadables));
3051 ThreadList &thread_list = process->GetThreadList();
3055 if (!reg_context->SetPC(file_entry_addr)) {
3063 module->GetFileSpec().GetPath(path, sizeof(path));
3068 module->GetFileSpec().GetPath(path, sizeof(path));
3074 if (module_spec_file) {
3075 module_spec_file->
GetPath(path,
sizeof(path));
3081 std::string uuid_str;
3090 if (num_matches > 1) {
3092 "multiple modules match%s%s%s%s:", path[0] ?
" file=" :
"", path,
3093 !uuid_str.empty() ?
" uuid=" :
"", uuid_str.c_str());
3094 for (
size_t i = 0; i < num_matches; ++i) {
3102 "no modules were found that match%s%s%s%s",
3103 path[0] ?
" file=" :
"", path, !uuid_str.empty() ?
" uuid=" :
"",
3108 result.
AppendError(
"either the \"--file <module>\" or the \"--uuid "
3109 "<uuid>\" option must be specified.\n");
3123#pragma mark CommandObjectTargetModulesList
3125#define LLDB_OPTIONS_target_modules_list
3126#include "CommandOptions.inc"
3141 if (short_option ==
'g') {
3143 }
else if (short_option ==
'a') {
3147 unsigned long width = 0;
3148 option_arg.getAsInteger(0, width);
3161 return llvm::ArrayRef(g_target_modules_list_options);
3173 interpreter,
"target modules list",
3174 "List current executable and dependent shared library images.") {
3185 const bool use_global_module_list =
m_options.m_use_global_module_list;
3202 "Couldn't find module matching address: 0x%" PRIx64,
3207 "Couldn't find module containing address: 0x%" PRIx64,
3213 size_t num_modules = 0;
3219 std::unique_lock<std::recursive_mutex> guard(
3225 if (use_global_module_list) {
3235 &target, arg.c_str(), module_list, use_global_module_list);
3236 if (num_matches == 0) {
3245 module_list_ptr = &module_list;
3248 std::unique_lock<std::recursive_mutex> lock;
3249 if (module_list_ptr !=
nullptr) {
3251 std::unique_lock<std::recursive_mutex>(module_list_ptr->
GetMutex());
3253 num_modules = module_list_ptr->
GetSize();
3256 if (num_modules > 0) {
3257 for (uint32_t image_idx = 0; image_idx < num_modules; ++image_idx) {
3260 if (module_list_ptr) {
3262 module = module_sp.get();
3264 module = Module::GetAllocatedModuleAtIndex(image_idx);
3265 module_sp =
module->shared_from_this();
3268 const size_t indent = strm.
Printf(
"[%3u] ", image_idx);
3274 if (use_global_module_list)
3276 "the global module list has no matching modules");
3278 result.
AppendError(
"the target has no matching modules");
3280 if (use_global_module_list)
3281 result.
AppendError(
"the global module list is empty");
3284 "the target has no associated executable images");
3291 if (module ==
nullptr) {
3296 bool dump_object_name =
false;
3298 m_options.m_format_array.push_back(std::make_pair(
'u', 0));
3299 m_options.m_format_array.push_back(std::make_pair(
'h', 0));
3300 m_options.m_format_array.push_back(std::make_pair(
'f', 0));
3301 m_options.m_format_array.push_back(std::make_pair(
'S', 0));
3303 const size_t num_entries =
m_options.m_format_array.size();
3304 bool print_space =
false;
3305 for (
size_t i = 0; i < num_entries; ++i) {
3309 const char format_char =
m_options.m_format_array[i].first;
3310 uint32_t width =
m_options.m_format_array[i].second;
3311 switch (format_char) {
3322 dump_object_name =
true;
3331 dump_object_name =
true;
3338 uint32_t addr_nibble_width =
3341 ObjectFile *objfile =
module->GetObjectFile();
3348 base_addr.
Dump(&strm, &target,
3352 if (format_char ==
'o') {
3354 strm.
Printf(
"0x%*.*" PRIx64, addr_nibble_width,
3359 strm.
Printf(
"0x%*.*" PRIx64, addr_nibble_width,
3360 addr_nibble_width, load_addr);
3371 strm.
Printf(
"%*s", addr_nibble_width + 2,
"");
3376 size_t ref_count = 0;
3377 char in_shared_cache =
'Y';
3379 ModuleSP module_sp(module->shared_from_this());
3381 in_shared_cache =
'N';
3384 ref_count = module_sp.use_count() - 1;
3387 strm.
Printf(
"{%c %*" PRIu64
"}", in_shared_cache, width, (uint64_t)ref_count);
3389 strm.
Printf(
"{%c %" PRIu64
"}", in_shared_cache, (uint64_t)ref_count);
3396 symbol_file->GetObjectFile()->GetFileSpec();
3397 if (format_char ==
'S') {
3399 if (!symfile_spec || symfile_spec == module->
GetFileSpec()) {
3400 print_space =
false;
3404 strm.
Printf(
"\n%*s", indent,
"");
3407 dump_object_name =
true;
3410 strm.
Printf(
"%.*s", width,
"<NONE>");
3415 llvm::AlignStyle::Left, width));
3419 strm.
Printf(
"%p",
static_cast<void *
>(module));
3430 if (dump_object_name) {
3431 const char *object_name =
module->GetObjectName().GetCString();
3433 strm.
Printf(
"(%s)", object_name);
3441#pragma mark CommandObjectTargetModulesShowUnwind
3444#define LLDB_OPTIONS_target_modules_show_unwind
3445#include "CommandOptions.inc"
3470 switch (short_option) {
3472 m_str = std::string(option_arg);
3478 "invalid address string '%s'", option_arg.str().c_str());
3483 m_str = std::string(option_arg);
3488 bool value, success;
3494 "invalid boolean value '{}' passed for -c option", option_arg);
3499 llvm_unreachable(
"Unimplemented option");
3513 return llvm::ArrayRef(g_target_modules_show_unwind_options);
3527 interpreter,
"target modules show-unwind",
3528 "Show synthesized unwind instructions for a function.", nullptr,
3529 eCommandRequiresTarget | eCommandRequiresProcess |
3530 eCommandProcessMustBeLaunched | eCommandProcessMustBePaused) {}
3542 abi = process->
GetABI().get();
3544 if (process ==
nullptr) {
3546 "You must have a process running to use this command.");
3552 result.
AppendError(
"the process must be paused to use this command");
3558 result.
AppendError(
"the process must be paused to use this command");
3570 function_options, sc_list);
3576 module_sp->ResolveSymbolContextForAddress(addr,
3577 eSymbolContextEverything, sc);
3584 "address-expression or function name option must be specified.");
3595 if (sc.symbol ==
nullptr && sc.function ==
nullptr)
3597 if (!sc.module_sp || sc.module_sp->GetObjectFile() ==
nullptr)
3599 Address addr = sc.GetFunctionOrSymbolAddress();
3609 UnwindTable &uw_table = sc.module_sp->GetUnwindTable();
3616 if (!func_unwinders_sp)
3620 "UNWIND PLANS for {0}`{1} (start addr {2:x})\n",
3621 sc.module_sp->GetPlatformFileSpec().GetFilename(), funcname,
3627 for (
size_t i = 0; i < count; i++) {
3629 if (strcmp(funcname.
GetCString(), trap_func_name) == 0)
3632 "treated as a trap handler function via user setting.\n");
3636 const std::vector<ConstString> trap_handler_names(
3637 platform_sp->GetTrapHandlerSymbolNames());
3638 for (
ConstString trap_name : trap_handler_names) {
3639 if (trap_name == funcname) {
3642 "name is listed by the platform as a trap handler.\n");
3649 if (std::shared_ptr<const UnwindPlan> plan_sp =
3650 func_unwinders_sp->GetUnwindPlanAtNonCallSite(*target, *thread)) {
3652 "Asynchronous (not restricted to call-sites) UnwindPlan is '{0}'\n",
3653 plan_sp->GetSourceName());
3655 if (std::shared_ptr<const UnwindPlan> plan_sp =
3656 func_unwinders_sp->GetUnwindPlanAtCallSite(*target, *thread)) {
3658 "Synchronous (restricted to call-sites) UnwindPlan is '{0}'\n",
3659 plan_sp->GetSourceName());
3661 if (std::shared_ptr<const UnwindPlan> plan_sp =
3662 func_unwinders_sp->GetUnwindPlanFastUnwind(*target, *thread)) {
3664 plan_sp->GetSourceName());
3669 if (std::shared_ptr<const UnwindPlan> plan_sp =
3670 func_unwinders_sp->GetAssemblyUnwindPlan(*target, *thread)) {
3672 "Assembly language inspection UnwindPlan:\n");
3678 if (std::shared_ptr<const UnwindPlan> plan_sp =
3679 func_unwinders_sp->GetObjectFileUnwindPlan(*target)) {
3686 if (std::shared_ptr<const UnwindPlan> plan_sp =
3687 func_unwinders_sp->GetObjectFileAugmentedUnwindPlan(*target,
3695 if (std::shared_ptr<const UnwindPlan> plan_sp =
3696 func_unwinders_sp->GetEHFrameUnwindPlan(*target)) {
3703 if (std::shared_ptr<const UnwindPlan> plan_sp =
3704 func_unwinders_sp->GetEHFrameAugmentedUnwindPlan(*target,
3712 if (std::shared_ptr<const UnwindPlan> plan_sp =
3713 func_unwinders_sp->GetDebugFrameUnwindPlan(*target)) {
3720 if (std::shared_ptr<const UnwindPlan> plan_sp =
3721 func_unwinders_sp->GetDebugFrameAugmentedUnwindPlan(*target,
3729 if (std::shared_ptr<const UnwindPlan> plan_sp =
3730 func_unwinders_sp->GetArmUnwindUnwindPlan(*target)) {
3737 if (std::shared_ptr<const UnwindPlan> plan_sp =
3738 func_unwinders_sp->GetSymbolFileUnwindPlan(*thread)) {
3745 if (std::shared_ptr<const UnwindPlan> plan_sp =
3746 func_unwinders_sp->GetCompactUnwindUnwindPlan(*target)) {
3753 if (std::shared_ptr<const UnwindPlan> plan_sp =
3754 func_unwinders_sp->GetUnwindPlanFastUnwind(*target, *thread)) {
3763 if (
UnwindPlanSP plan_sp = abi_sp->CreateDefaultUnwindPlan()) {
3770 if (
UnwindPlanSP plan_sp = abi_sp->CreateFunctionEntryUnwindPlan()) {
3772 "Arch default at entry point UnwindPlan:\n");
3788#define LLDB_OPTIONS_target_modules_lookup
3789#include "CommandOptions.inc"
3816 switch (short_option) {
3824 if (option_arg.getAsInteger(0,
m_offset))
3826 "invalid offset string '%s'", option_arg.str().c_str());
3830 m_str = std::string(option_arg);
3835 m_file.SetFile(option_arg, FileSpec::Style::native);
3846 "invalid line number string '%s'", option_arg.str().c_str());
3853 m_str = std::string(option_arg);
3858 m_str = std::string(option_arg);
3863 m_str = std::string(option_arg);
3883 llvm_unreachable(
"Unimplemented option");
3908 "conjunction with --verbose.");
3914 return llvm::ArrayRef(g_target_modules_lookup_options);
3935 "Look up information within executable and "
3936 "dependent shared library images.",
3937 nullptr, eCommandRequiresTarget) {
3946 bool &syntax_error) {
3964 const SymbolContext &sym_ctx(frame->GetSymbolContext(eSymbolContextModule));
3994 eSymbolContextEverything |
3996 ?
static_cast<int>(eSymbolContextVariable)
4041 m_options.m_use_regex, function_options,
4066 syntax_error =
true;
4077 bool syntax_error =
false;
4079 uint32_t num_successful_lookups = 0;
4088 num_successful_lookups++;
4098 std::lock_guard<std::recursive_mutex> guard(target_modules.
GetMutex());
4099 if (target_modules.
GetSize() == 0) {
4100 result.
AppendError(
"the target has no associated executable images");
4108 num_successful_lookups++;
4113 const char *arg_cstr;
4118 const size_t num_matches =
4120 if (num_matches > 0) {
4121 for (
size_t j = 0; j < num_matches; ++j) {
4126 num_successful_lookups++;
4132 "unable to find an image that matches '{0}'", arg_cstr);
4136 if (num_successful_lookups > 0)
4145#pragma mark CommandObjectMultiwordImageSearchPaths
4154 interpreter,
"target modules search-paths",
4155 "Commands for managing module search paths for a target.",
4156 "target modules search-paths <subcommand> [<subcommand-options>]") {
4178#pragma mark CommandObjectTargetModules
4187 "Commands for accessing information for one or "
4188 "more target modules.",
4189 "target modules <sub-command> ...") {
4223 interpreter,
"target symbols add",
4224 "Add a debug symbol file to one of the target's current modules by "
4225 "specifying a path to a debug symbols file or by using the options "
4226 "to specify a module.",
4227 "target symbols add <cmd-options> [<symfile>]",
4228 eCommandRequiresTarget),
4232 "Locate the debug symbols for the shared library specified by "
4236 "Locate the debug symbols for the currently selected frame.", false,
4239 "Locate the debug symbols for every frame in "
4240 "the current call stack.",
4263 if (!symbol_fspec) {
4265 "one or more executable image paths must be specified");
4270 symbol_fspec.
GetPath(symfile_path,
sizeof(symfile_path));
4285 if (symfile_module_specs.
GetSize() > 0) {
4291 symfile_module_spec)) {
4295 symfile_uuid_module_spec.
GetUUID() = symfile_module_spec.
GetUUID();
4301 if (matching_modules.
IsEmpty()) {
4304 const size_t num_symfile_module_specs = symfile_module_specs.
GetSize();
4306 i < num_symfile_module_specs && matching_modules.
IsEmpty(); ++i) {
4308 i, symfile_module_spec)) {
4312 symfile_uuid_module_spec.
GetUUID() =
4313 symfile_module_spec.
GetUUID();
4324 if (matching_modules.
IsEmpty())
4327 while (matching_modules.
IsEmpty()) {
4331 if (!filename_no_extension)
4343 if (matching_modules.
GetSize() > 1) {
4345 "use the --uuid option to resolve the "
4351 if (matching_modules.
GetSize() == 1) {
4357 module_sp->SetSymbolFileFileSpec(symbol_fspec);
4363 if (object_file && object_file->
GetFileSpec() == symbol_fspec) {
4365 const FileSpec &module_fs = module_sp->GetFileSpec();
4367 "symbol file '{0}' has been added to '{1}'", symfile_path,
4373 module_list.
Append(module_sp);
4378 std::list<Status> errors;
4380 for (
const auto &err : errors)
4389 module_sp->SetSymbolFileFileSpec(
FileSpec());
4394 ss_symfile_uuid <<
" (";
4396 ss_symfile_uuid <<
')';
4399 "symbol file '%s'%s does not match any existing module%s", symfile_path,
4401 !llvm::sys::fs::is_regular_file(symbol_fspec.
GetPath())
4402 ?
"\n please specify the full path to the symbol file"
4429 error_strm.
PutCString(
"unable to find debug symbols for UUID ");
4448 module_spec.
GetFileSpec() = module_sp->GetFileSpec();
4450 module_spec.
GetUUID() = module_sp->GetUUID();
4459 "unable to find debug symbols for the executable file ");
4474 "a process must exist in order to use the --frame option");
4493 if (!frame_module_sp) {
4499 module_spec.
GetUUID() = frame_module_sp->GetUUID();
4501 module_spec.
GetFileSpec() = frame_module_sp->GetPlatformFileSpec();
4504 result.
AppendError(
"unable to find debug symbols for the current frame");
4517 "a process must exist in order to use the --stack option");
4534 bool symbols_found =
false;
4535 uint32_t frame_count = thread->GetStackFrameCount();
4536 for (uint32_t i = 0; i < frame_count; ++i) {
4540 frame_sp->GetSymbolContext(eSymbolContextModule).module_sp);
4541 if (!frame_module_sp)
4545 module_spec.
GetUUID() = frame_module_sp->GetUUID();
4546 module_spec.
GetFileSpec() = frame_module_sp->GetPlatformFileSpec();
4549 bool current_frame_flush =
false;
4551 symbols_found =
true;
4552 flush |= current_frame_flush;
4555 if (!symbols_found) {
4557 "unable to find debug symbols in the current call stack");
4569 const bool uuid_option_set =
4571 const bool file_option_set =
m_file_option.GetOptionValue().OptionWasSet();
4572 const bool frame_option_set =
4574 const bool stack_option_set =
4579 if (uuid_option_set)
4581 else if (file_option_set)
4583 else if (frame_option_set)
4585 else if (stack_option_set)
4588 result.
AppendError(
"one or more symbol file paths must be specified, "
4589 "or options must be specified");
4591 if (uuid_option_set) {
4592 result.
AppendError(
"specify either one or more paths to symbol files "
4593 "or use the --uuid option without arguments");
4594 }
else if (frame_option_set) {
4595 result.
AppendError(
"specify either one or more paths to symbol files "
4596 "or use the --frame option without arguments");
4597 }
else if (file_option_set && argc > 1) {
4598 result.
AppendError(
"specify at most one symbol file path when "
4599 "--shlib option is set");
4603 for (
auto &entry : args.
entries()) {
4604 if (!entry.ref().empty()) {
4606 symbol_file_spec.
SetFile(entry.ref(), FileSpec::Style::native);
4608 if (file_option_set) {
4615 ->ResolveSymbolFile(*target, module_spec, symfile_spec)
4620 bool symfile_exists =
4623 if (symfile_exists) {
4627 std::string resolved_symfile_path =
4629 if (resolved_symfile_path != entry.ref()) {
4631 "invalid module path '%s' with resolved path '%s'",
4632 entry.c_str(), resolved_symfile_path.c_str());
4658#pragma mark CommandObjectTargetSymbols
4667 interpreter,
"target symbols",
4668 "Commands for adding and managing debug symbol files.",
4669 "target symbols <sub-command> ...") {
4683#pragma mark CommandObjectTargetStopHookAdd
4686#define LLDB_OPTIONS_target_stop_hook_add
4687#include "CommandOptions.inc"
4699 return llvm::ArrayRef(g_target_stop_hook_add_options);
4705 const int short_option =
4706 g_target_stop_hook_add_options[option_idx].short_option;
4708 switch (short_option) {
4715 if (option_arg.getAsInteger(0,
m_line_end)) {
4717 "invalid end line number: \"%s\"", option_arg.str().c_str());
4724 bool value, success;
4730 "invalid boolean value '%s' passed for -G option",
4731 option_arg.str().c_str());
4736 "invalid start line number: \"%s\"", option_arg.str().c_str());
4765 "invalid thread id string '%s'", option_arg.str().c_str());
4782 "invalid thread index string '%s'", option_arg.str().c_str());
4792 bool value, success;
4798 "invalid boolean value '%s' passed for -F option",
4799 option_arg.str().c_str());
4803 llvm_unreachable(
"Unimplemented option");
4838 eFunctionNameTypeAuto;
4856 "Add a hook to be executed when the target stops."
4857 "The hook can either be a list of commands or an "
4858 "appropriately defined Python class. You can also "
4859 "add filters so the hook only runs a certain stop "
4861 "target stop-hook add"),
4867Command Based stop-hooks:
4868-------------------------
4869 Stop hooks can run a list of lldb commands by providing one or more
4870 --one-liner options. The commands will get run in the order they are added.
4871 Or you can provide no commands, in which case you will enter a command editor
4872 where you can enter the commands to be run.
4874Python Based Stop Hooks:
4875------------------------
4876 Stop hooks can be implemented with a suitably defined Python class, whose name
4877 is passed in the --python-class option.
4879 When the stop hook is added, the class is initialized by calling:
4881 def __init__(self, target, extra_args, internal_dict):
4883 target: The target that the stop hook is being added to.
4884 extra_args: An SBStructuredData Dictionary filled with the -key -value
4885 option pairs passed to the command.
4886 dict: An implementation detail provided by lldb.
4888 Then when the stop-hook triggers, lldb will run the 'handle_stop' method.
4889 The method has the signature:
4891 def handle_stop(self, exe_ctx, stream):
4893 exe_ctx: An SBExecutionContext for the thread that has stopped.
4894 stream: An SBStream, anything written to this stream will be printed in the
4895 the stop message when the process stops.
4897 Return Value: The method returns "should_stop". If should_stop is false
4898 from all the stop hook executions on threads that stopped
4899 with a reason, then the process will continue. Note that this
4900 will happen only after all the stop hooks are run.
4904 Stop hooks can be set to always run, or to only run when the stopped thread
4905 matches the filter options passed on the command line. The available filter
4906 options include a shared library or a thread or queue specification,
4907 a line range in a source file, a function name or a class name.
4927 "Enter your stop hook command(s). Type 'DONE' to end.\n");
4933 std::string &line)
override {
4939 locked_stream.
Printf(
"error: stop hook #%" PRIu64
4940 " aborted, no commands.\n",
4946 Target::StopHookCommandLine *hook_ptr =
4947 static_cast<Target::StopHookCommandLine *
>(
m_stop_hook_sp.get());
4952 LockedStreamFile locked_stream = output_sp->Lock();
4953 locked_stream.
Printf(
"Stop hook #%" PRIu64
" added.\n",
4962 void DoExecute(Args &command, CommandReturnObject &result)
override {
4968 Target::StopHook::StopHookKind::CommandBased
4969 : Target::StopHook::StopHookKind::ScriptBased);
4972 std::unique_ptr<SymbolContextSpecifier> specifier_up;
4974 specifier_up = std::make_unique<SymbolContextSpecifier>(
4978 specifier_up->AddSpecification(
4984 specifier_up->AddSpecification(
4990 specifier_up->AddSpecification(
m_options.m_file_name.c_str(),
4995 specifier_up->AddLineSpecification(
5001 specifier_up->AddLineSpecification(
5005 if (!
m_options.m_function_name.empty()) {
5006 specifier_up->AddSpecification(
5013 new_hook_sp->SetSpecifier(specifier_up.release());
5016 new_hook_sp->SetRunAtInitialStop(
m_options.m_at_initial_stop);
5021 ThreadSpec *thread_spec =
new ThreadSpec();
5036 new_hook_sp->SetThreadSpecifier(thread_spec);
5046 new_hook_sp->GetID());
5049 Target::StopHookScripted *hook_ptr =
5050 static_cast<Target::StopHookScripted *
>(new_hook_sp.get());
5054 if (
error.Success())
5056 new_hook_sp->GetID());
5080#pragma mark CommandObjectTargetStopHookDelete
5088 "Delete a stop-hook.",
5089 "target stop-hook delete [<idx>]") {
5092Deletes the stop hook by index.
5094At any given stop, all enabled stop hooks that pass the stop filter will
5095get a chance to run. That means if one stop-hook deletes another stop hook
5096while executing, the deleted stop hook will still fire for the stop at which
5117 if (num_args == 0) {
5125 for (
size_t i = 0; i < num_args; i++) {
5143#pragma mark CommandObjectTargetStopHookEnableDisable
5150 bool enable,
const char *name,
5151 const char *help,
const char *syntax)
5173 if (num_args == 0) {
5176 for (
size_t i = 0; i < num_args; i++) {
5198#pragma mark CommandObjectTargetStopHookList
5201#define LLDB_OPTIONS_target_stop_hook_list
5202#include "CommandOptions.inc"
5208 "List all stop-hooks.") {}
5224 switch (short_option) {
5229 llvm_unreachable(
"Unimplemented option");
5240 return llvm::ArrayRef(g_target_stop_hook_list_options);
5251 bool printed_hook =
false;
5256 printed_hook =
true;
5269#pragma mark CommandObjectMultiwordTargetStopHooks
5277 interpreter,
"target stop-hook",
5278 "Commands for operating on debugger target stop-hooks.",
5279 "target stop-hook <subcommand> [<subcommand-options>]") {
5287 interpreter,
false,
"target stop-hook disable [<id>]",
5288 "Disable a stop-hook.",
"target stop-hook disable")));
5291 interpreter,
true,
"target stop-hook enable [<id>]",
5292 "Enable a stop-hook.",
"target stop-hook enable")));
5300#pragma mark CommandObjectTargetHookAdd
5302#define LLDB_OPTIONS_target_hook_add
5303#include "CommandOptions.inc"
5314 return llvm::ArrayRef(g_target_hook_add_options);
5320 const int short_option =
5321 g_target_hook_add_options[option_idx].short_option;
5322 switch (short_option) {
5341 uint32_t thread_index;
5342 if (option_arg.getAsInteger(0, thread_index))
5344 option_arg.str().c_str());
5352 if (option_arg.getAsInteger(0, thread_id))
5354 option_arg.str().c_str());
5374 if (option_arg.getAsInteger(0, line))
5376 "invalid start line number '%s'", option_arg.str().c_str());
5384 if (option_arg.getAsInteger(0, line))
5386 "invalid end line number '%s'", option_arg.str().c_str());
5401 bool value, success;
5407 "invalid boolean value '%s' passed for -G option",
5408 option_arg.str().c_str());
5412 bool value, success;
5418 "invalid boolean value '%s' passed for -I option",
5419 option_arg.str().c_str());
5423 llvm_unreachable(
"unhandled option");
5475 interpreter,
"target hook add",
5476 "Add a hook to be executed on target lifecycle events.",
5484 Specify which triggers the hook responds to with --on-load (-L),
5485 --on-unload (-u), and/or --on-stop (-S). At least one trigger is required.
5486 Provide commands with --one-liner (-o), or omit -o to enter an interactive
5487 command editor. All commands run for every trigger the hook is signed up
5488 for; there is no per-trigger command list.
5491 target hook add -L -o "script print('module loaded')"
5492 target hook add -L -u -o "script print('module event')"
5493 target hook add -S -o "bt"
5494 target hook add -L -u -S -o "script print('all events')"
5495 target hook add -S -s mylib.so -n main -o "bt"
5496 target hook add -S -G true -o "thread info"
5500 Provide a Python class with --python-class (-P). The class controls which
5501 events it handles by implementing the corresponding methods; you do not
5502 specify triggers on the command line. Use -k <key> -v <value> to pass
5503 extra_args to the class constructor.
5506 target hook add -P mymodule.MyHook
5507 target hook add -P mymodule.MyHook -k verbose -v true
5509 The Python class should implement at least one of these methods:
5512 def __init__(self, target, extra_args, internal_dict):
5513 self.target = target
5514 def handle_module_loaded(self, stream):
5516 def handle_module_unloaded(self, stream):
5518 def handle_stop(self, exe_ctx, stream):
5519 return True # True = should_stop, False = continue
5523 Filters (-s, -f, -l, -e, -c, -n, -x, -t, -T, -q) restrict when the hook
5524 fires. They apply to both command-based and Python class hooks.
5547 "Enter your hook command(s). Type 'DONE' to end.\n");
5553 std::string &line)
override {
5558 LockedStreamFile locked_stream = error_sp->Lock();
5559 locked_stream.
Printf(
"error: hook #%" PRIu64
5560 " aborted, no commands.\n",
5565 auto *hook =
static_cast<Target::HookCommandLine *
>(
m_hook_sp.get());
5566 hook->SetActionFromString(line);
5569 LockedStreamFile locked_stream = output_sp->Lock();
5570 locked_stream.
Printf(
"Hook #%" PRIu64
" added.\n",
5579 void DoExecute(Args &command, CommandReturnObject &result)
override {
5588 result.
AppendError(
"at least one trigger must be specified: "
5589 "--on-load (-L), --on-unload (-u), or --on-stop (-S)");
5594 is_python_class ? Target::Hook::HookKind::ScriptBased
5595 : Target::Hook::HookKind::CommandBased;
5599 if (!is_python_class) {
5602 static_cast<Target::HookCommandLine *
>(new_hook_sp.get());
5603 uint32_t trigger_mask = 0;
5610 cmd_hook->SetTriggerMask(trigger_mask);
5617 auto specifier_up = std::make_unique<SymbolContextSpecifier>(
5621 specifier_up->AddSpecification(
5626 specifier_up->AddSpecification(
5631 specifier_up->AddSpecification(
m_options.m_file_name.c_str(),
5635 specifier_up->AddLineSpecification(
5640 specifier_up->AddLineSpecification(
5644 specifier_up->AddSpecification(
5648 new_hook_sp->SetSCSpecifier(specifier_up.release());
5653 ThreadSpec *thread_spec =
new ThreadSpec();
5667 new_hook_sp->SetThreadSpecifier(thread_spec);
5677 new_hook_sp->GetID());
5679 auto *hook =
static_cast<Target::HookScripted *
>(new_hook_sp.get());
5683 if (callback_error.
Fail()) {
5690 new_hook_sp->GetID());
5706#pragma mark CommandObjectTargetHookDelete
5712 "target hook delete [<id>]") {
5748#pragma mark CommandObjectTargetHookEnableDisable
5753 bool enable,
const char *name,
5754 const char *help,
const char *syntax)
5792#pragma mark CommandObjectTargetHookModify
5794#define LLDB_OPTIONS_target_hook_modify
5795#include "CommandOptions.inc"
5807 return llvm::ArrayRef(g_target_hook_modify_options);
5813 const int short_option =
5814 g_target_hook_modify_options[option_idx].short_option;
5815 switch (short_option) {
5823 llvm_unreachable(
"unhandled option");
5839 "Modify trigger settings on a hook.",
5840 "target hook modify [--enable-trigger <name>] "
5841 "[--disable-trigger <name>] [<id>]") {
5844Modify trigger settings on command-based hooks. Scripted hooks derive their
5845triggers from the class methods and cannot be modified.
5847If no hook ID is given, the last added hook is modified.
5849Valid trigger names: load, unload, stop.
5852 target hook modify --enable-trigger stop 1
5853 target hook modify --disable-trigger load 1
5854 target hook modify --enable-trigger stop (modifies last added hook)
5866 if (name ==
"unload")
5878 result.
AppendError(
"at least one of --enable-trigger or "
5879 "--disable-trigger must be specified");
5887 if (num_hooks == 0) {
5908 if (hook_sp->GetHookKind() != Target::Hook::HookKind::CommandBased) {
5909 result.
AppendError(
"cannot modify triggers on a scripted hook; "
5910 "triggers are determined by the class methods");
5913 auto *cmd_hook =
static_cast<Target::HookCommandLine *
>(hook_sp.get());
5915 if (!
m_options.m_enable_trigger.empty()) {
5919 "Valid names: load, unload, stop",
5923 cmd_hook->AddTrigger(trigger);
5926 if (!
m_options.m_disable_trigger.empty()) {
5930 "Valid names: load, unload, stop",
5934 cmd_hook->RemoveTrigger(trigger);
5944#pragma mark CommandObjectTargetHookList
5950 "target hook list") {}
5958 if (num_hooks == 0) {
5961 for (
size_t i = 0; i < num_hooks; i++) {
5972#pragma mark CommandObjectMultiwordTargetHooks
5978 interpreter,
"target hook",
5979 "Commands for operating on target hooks.",
5980 "target hook <subcommand> [<subcommand-options>]") {
5987 interpreter,
false,
"target hook disable",
5988 "Disable a hook.",
"target hook disable [<id> ...]")));
5991 interpreter,
true,
"target hook enable",
5992 "Enable a hook.",
"target hook enable [<id> ...]")));
6002#pragma mark CommandObjectTargetDumpTypesystem
6009 interpreter,
"target dump typesystem",
6010 "Dump the state of the target's internal type system. Intended to "
6011 "be used for debugging LLDB itself.",
6012 nullptr, eCommandRequiresTarget) {}
6028#pragma mark CommandObjectTargetDumpSectionLoadList
6035 interpreter,
"target dump section-load-list",
6036 "Dump the state of the target's internal section load list. "
6037 "Intended to be used for debugging LLDB itself.",
6038 nullptr, eCommandRequiresTarget) {}
6050#pragma mark CommandObjectTargetDump
6058 interpreter,
"target dump",
6059 "Commands for dumping information about the target.",
6060 "target dump [typesystem|section-load-list]") {
6072#pragma mark CommandObjectTargetFrameProvider
6074#define LLDB_OPTIONS_target_frame_provider_register
6075#include "CommandOptions.inc"
6081 interpreter,
"target frame-provider register",
6082 "Register frame provider for all threads in this target.", nullptr,
6083 eCommandRequiresTarget),
6096 uint32_t index)
override {
6097 return std::string(
"");
6122 result.
SetError(id_or_err.takeError());
6127 "successfully registered scripted frame provider '{0}' for target",
6139 interpreter,
"target frame-provider clear",
6140 "Clear all registered frame providers from this target.", nullptr,
6141 eCommandRequiresTarget) {}
6163 interpreter,
"target frame-provider list",
6164 "List all registered frame providers for the target.", nullptr,
6165 eCommandRequiresTarget) {}
6176 if (descriptors.empty()) {
6177 result.
AppendMessage(
"no frame providers registered for this target.");
6183 strm << llvm::formatv(
"{0} frame provider(s) registered:\n\n",
6184 descriptors.size());
6186 for (
const auto &entry : descriptors) {
6188 descriptor.
Dump(&strm);
6200 interpreter,
"target frame-provider remove",
6201 "Remove a registered frame provider from the target by id.",
6202 "target frame-provider remove <provider-id>",
6203 eCommandRequiresTarget) {
6215 std::vector<uint32_t> removed_provider_ids;
6217 uint32_t provider_id = 0;
6218 if (!llvm::to_integer(command[i].ref(), provider_id)) {
6219 result.
AppendError(
"target frame-provider remove requires integer "
6220 "provider id argument");
6226 "no frame provider named '%u' found in target", provider_id);
6229 removed_provider_ids.push_back(provider_id);
6232 if (
size_t num_removed_providers = removed_provider_ids.size()) {
6234 "Successfully removed {0} frame-providers.", num_removed_providers);
6237 result.
AppendError(
"0 frame providers removed.\n");
6246 interpreter,
"target frame-provider",
6247 "Commands for registering and viewing frame providers for the "
6249 "target frame-provider [<sub-command-options>] ") {
6267#pragma mark CommandObjectMultiwordTarget
6274 "Commands for operating on debugger targets.",
6275 "target <subcommand> [<subcommand-options>]") {
static bool GetSeparateDebugInfoList(StructuredData::Array &list, Module *module, bool errors_only, bool load_all_debug_info)
static uint32_t DumpTargetList(TargetList &target_list, bool show_stopped_process_status, Stream &strm)
static void DumpModuleUUID(Stream &strm, Module *module)
static void DumpModuleSections(CommandInterpreter &interpreter, Stream &strm, Module *module)
static void DumpModuleArchitecture(Stream &strm, Module *module, bool full_triple, uint32_t width)
static bool LookupAddressInModule(CommandInterpreter &interpreter, Stream &strm, Module *module, uint32_t resolve_mask, lldb::addr_t raw_addr, lldb::addr_t offset, bool verbose, bool all_ranges)
static void DumpTargetInfo(uint32_t target_idx, Target *target, const char *prefix_cstr, bool show_stopped_process_status, Stream &strm)
static void DumpDirectory(Stream &strm, const FileSpec *file_spec_ptr, uint32_t width)
static uint32_t LookupSymbolInModule(CommandInterpreter &interpreter, Stream &strm, Module *module, const char *name, bool name_is_regex, bool verbose, bool all_ranges)
static size_t LookupTypeInModule(Target *target, CommandInterpreter &interpreter, Stream &strm, Module *module, const char *name_cstr, bool name_is_regex)
static bool DumpModuleSymbolFile(Stream &strm, Module *module)
static void DumpFullpath(Stream &strm, const FileSpec *file_spec_ptr, uint32_t width)
static void DumpDwoFilesTable(Stream &strm, StructuredData::Array &dwo_listings)
static size_t LookupFunctionInModule(CommandInterpreter &interpreter, Stream &strm, Module *module, const char *name, bool name_is_regex, const ModuleFunctionSearchOptions &options, bool verbose, bool all_ranges)
static size_t LookupTypeHere(Target *target, CommandInterpreter &interpreter, Stream &strm, Module &module, const char *name_cstr, bool name_is_regex)
static uint32_t DumpCompileUnitLineTable(CommandInterpreter &interpreter, Stream &strm, Module *module, const FileSpec &file_spec, lldb::DescriptionLevel desc_level)
static void DumpBasename(Stream &strm, const FileSpec *file_spec_ptr, uint32_t width)
static size_t DumpModuleObjfileHeaders(Stream &strm, ModuleList &module_list)
static uint32_t LookupFileAndLineInModule(CommandInterpreter &interpreter, Stream &strm, Module *module, const FileSpec &file_spec, uint32_t line, bool check_inlines, bool verbose, bool all_ranges)
static void DumpSymbolContextList(ExecutionContextScope *exe_scope, Stream &strm, const SymbolContextList &sc_list, bool verbose, bool all_ranges, std::optional< Stream::HighlightSettings > settings=std::nullopt)
static void DumpOsoFilesTable(Stream &strm, StructuredData::Array &oso_listings)
static size_t FindModulesByName(Target *target, const char *module_name, ModuleList &module_list, bool check_global_list)
static void DumpModuleSymtab(CommandInterpreter &interpreter, Stream &strm, Module *module, SortOrder sort_order, Mangled::NamePreference name_preference)
static llvm::raw_ostream & error(Stream &strm)
#define INTERRUPT_REQUESTED(debugger,...)
This handy define will keep you from having to generate a report for the interruption by hand.
#define LLDB_LOGF(log,...)
#define LLDB_SCOPED_TIMERF(...)
CommandObjectMultiwordTargetHooks(CommandInterpreter &interpreter)
~CommandObjectMultiwordTargetHooks() override=default
~CommandObjectMultiwordTargetStopHooks() override=default
CommandObjectMultiwordTargetStopHooks(CommandInterpreter &interpreter)
OptionGroupString m_label
OptionGroupPlatform m_platform_options
~CommandObjectTargetCreate() override=default
Options * GetOptions() override
OptionGroupFile m_symbol_file
OptionGroupFile m_remote_file
OptionGroupOptions m_option_group
OptionGroupArchitecture m_arch_option
CommandObjectTargetCreate(CommandInterpreter &interpreter)
OptionGroupDependents m_add_dependents
OptionGroupFile m_core_file
void DoExecute(Args &command, CommandReturnObject &result) override
OptionGroupBoolean m_cleanup_option
OptionGroupOptions m_option_group
void DoExecute(Args &args, CommandReturnObject &result) override
CommandObjectTargetDelete(CommandInterpreter &interpreter)
OptionGroupBoolean m_all_option
~CommandObjectTargetDelete() override=default
Options * GetOptions() override
Dumps the SectionLoadList of the selected Target.
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetDumpSectionLoadList() override=default
CommandObjectTargetDumpSectionLoadList(CommandInterpreter &interpreter)
Dumps the TypeSystem of the selected Target.
CommandObjectTargetDumpTypesystem(CommandInterpreter &interpreter)
~CommandObjectTargetDumpTypesystem() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
Multi-word command for 'target dump'.
CommandObjectTargetDump(CommandInterpreter &interpreter)
~CommandObjectTargetDump() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetFrameProviderClear(CommandInterpreter &interpreter)
~CommandObjectTargetFrameProviderClear() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetFrameProviderList() override=default
CommandObjectTargetFrameProviderList(CommandInterpreter &interpreter)
OptionGroupPythonClassWithDict m_class_options
~CommandObjectTargetFrameProviderRegister() override=default
Options * GetOptions() override
OptionGroupOptions m_all_options
CommandObjectTargetFrameProviderRegister(CommandInterpreter &interpreter)
std::optional< std::string > GetRepeatCommand(Args ¤t_command_args, uint32_t index) override
Get the command that appropriate for a "repeat" of the current command.
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetFrameProviderRemove() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetFrameProviderRemove(CommandInterpreter &interpreter)
~CommandObjectTargetFrameProvider() override=default
CommandObjectTargetFrameProvider(CommandInterpreter &interpreter)
std::string m_thread_name
std::string m_function_name
std::string m_module_name
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void OptionParsingStarting(ExecutionContext *execution_context) override
std::vector< std::string > m_one_liner
~CommandOptions() override=default
CommandObjectTargetHookAdd(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
OptionGroupOptions m_all_options
OptionGroupPythonClassWithDict m_python_class_options
void IOHandlerInputComplete(IOHandler &io_handler, std::string &line) override
Called when a line or lines have been retrieved.
~CommandObjectTargetHookAdd() override=default
Options * GetOptions() override
void IOHandlerActivated(IOHandler &io_handler, bool interactive) override
CommandObjectTargetHookDelete(CommandInterpreter &interpreter)
~CommandObjectTargetHookDelete() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetHookEnableDisable() override=default
CommandObjectTargetHookEnableDisable(CommandInterpreter &interpreter, bool enable, const char *name, const char *help, const char *syntax)
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetHookList(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetHookList() override=default
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
void OptionParsingStarting(ExecutionContext *execution_context) override
std::string m_enable_trigger
std::string m_disable_trigger
Modify trigger settings on a hook.
void DoExecute(Args &command, CommandReturnObject &result) override
Options * GetOptions() override
static uint32_t ParseTriggerName(llvm::StringRef name)
CommandObjectTargetHookModify(CommandInterpreter &interpreter)
~CommandObjectTargetHookModify() override=default
CommandObjectTargetList(CommandInterpreter &interpreter)
void DoExecute(Args &args, CommandReturnObject &result) override
~CommandObjectTargetList() override=default
OptionGroupOptions m_option_group
OptionGroupFile m_symbol_file
CommandObjectTargetModulesAdd(CommandInterpreter &interpreter)
void DoExecute(Args &args, CommandReturnObject &result) override
OptionGroupUUID m_uuid_option_group
~CommandObjectTargetModulesAdd() override=default
Options * GetOptions() override
CommandObjectTargetModulesDumpClangAST(CommandInterpreter &interpreter)
Options * GetOptions() override
void DoExecute(Args &command, CommandReturnObject &result) override
OptionGroupString m_filter
~CommandObjectTargetModulesDumpClangAST() override=default
OptionGroupOptions m_option_group
~CommandObjectTargetModulesDumpClangPCMInfo() override=default
CommandObjectTargetModulesDumpClangPCMInfo(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
void OptionParsingStarting(ExecutionContext *execution_context) override
~CommandObjectTargetModulesDumpLineTable() override=default
Options * GetOptions() override
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetModulesDumpLineTable(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetModulesDumpObjfile() override=default
CommandObjectTargetModulesDumpObjfile(CommandInterpreter &interpreter)
CommandObjectTargetModulesDumpSections(CommandInterpreter &interpreter)
~CommandObjectTargetModulesDumpSections() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
void OptionParsingStarting(ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
~CommandOptions() override=default
OptionValueBoolean m_errors_only
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
OptionValueBoolean m_json
OptionValueBoolean m_load_all_debug_info
~CommandObjectTargetModulesDumpSeparateDebugInfoFiles() override=default
CommandObjectTargetModulesDumpSeparateDebugInfoFiles(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
Options * GetOptions() override
CommandObjectTargetModulesDumpSymfile(CommandInterpreter &interpreter)
~CommandObjectTargetModulesDumpSymfile() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
void OptionParsingStarting(ExecutionContext *execution_context) override
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
OptionValueBoolean m_prefer_mangled
Options * GetOptions() override
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetModulesDumpSymtab(CommandInterpreter &interpreter)
~CommandObjectTargetModulesDumpSymtab() override=default
~CommandObjectTargetModulesDump() override=default
CommandObjectTargetModulesDump(CommandInterpreter &interpreter)
CommandObjectTargetModulesImageSearchPaths(CommandInterpreter &interpreter)
~CommandObjectTargetModulesImageSearchPaths() override=default
bool m_use_global_module_list
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void OptionParsingStarting(ExecutionContext *execution_context) override
FormatWidthCollection m_format_array
std::vector< std::pair< char, uint32_t > > FormatWidthCollection
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
lldb::addr_t m_module_addr
CommandObjectTargetModulesList(CommandInterpreter &interpreter)
~CommandObjectTargetModulesList() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
void PrintModule(Target &target, Module *module, int indent, Stream &strm)
Options * GetOptions() override
OptionGroupBoolean m_pc_option
OptionGroupUInt64 m_slide_option
OptionGroupBoolean m_load_option
void DoExecute(Args &args, CommandReturnObject &result) override
Options * GetOptions() override
OptionGroupUUID m_uuid_option_group
~CommandObjectTargetModulesLoad() override=default
OptionGroupOptions m_option_group
CommandObjectTargetModulesLoad(CommandInterpreter &interpreter)
OptionGroupString m_file_option
~CommandOptions() override=default
void OptionParsingStarting(ExecutionContext *execution_context) override
Status OptionParsingFinished(ExecutionContext *execution_context) override
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
bool LookupInModule(CommandInterpreter &interpreter, Module *module, CommandReturnObject &result, bool &syntax_error)
Options * GetOptions() override
@ eLookupTypeFunctionOrSymbol
~CommandObjectTargetModulesLookup() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
bool LookupHere(CommandInterpreter &interpreter, CommandReturnObject &result, bool &syntax_error)
CommandObjectTargetModulesLookup(CommandInterpreter &interpreter)
CommandObjectTargetModulesModuleAutoComplete(CommandInterpreter &interpreter, const char *name, const char *help, const char *syntax, uint32_t flags=0)
~CommandObjectTargetModulesModuleAutoComplete() override=default
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
~CommandObjectTargetModulesSearchPathsAdd() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetModulesSearchPathsAdd(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetModulesSearchPathsClear() override=default
CommandObjectTargetModulesSearchPathsClear(CommandInterpreter &interpreter)
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
~CommandObjectTargetModulesSearchPathsInsert() override=default
CommandObjectTargetModulesSearchPathsInsert(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetModulesSearchPathsList() override=default
CommandObjectTargetModulesSearchPathsList(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetModulesSearchPathsQuery() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetModulesSearchPathsQuery(CommandInterpreter &interpreter)
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
void OptionParsingStarting(ExecutionContext *execution_context) override
~CommandOptions() override=default
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
@ eLookupTypeFunctionOrSymbol
CommandObjectTargetModulesShowUnwind(CommandInterpreter &interpreter)
void DoExecute(Args &command, CommandReturnObject &result) override
Options * GetOptions() override
~CommandObjectTargetModulesShowUnwind() override=default
CommandObjectTargetModulesSourceFileAutoComplete(CommandInterpreter &interpreter, const char *name, const char *help, const char *syntax, uint32_t flags)
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
~CommandObjectTargetModulesSourceFileAutoComplete() override=default
~CommandObjectTargetModules() override=default
const CommandObjectTargetModules & operator=(const CommandObjectTargetModules &)=delete
CommandObjectTargetModules(const CommandObjectTargetModules &)=delete
CommandObjectTargetModules(CommandInterpreter &interpreter)
~CommandObjectTargetSelect() override=default
void DoExecute(Args &args, CommandReturnObject &result) override
CommandObjectTargetSelect(CommandInterpreter &interpreter)
CommandObjectTargetShowLaunchEnvironment(CommandInterpreter &interpreter)
void DoExecute(Args &args, CommandReturnObject &result) override
~CommandObjectTargetShowLaunchEnvironment() override=default
uint32_t m_func_name_type_mask
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
std::string m_function_name
std::vector< std::string > m_one_liner
~CommandOptions() override=default
std::string m_thread_name
void OptionParsingStarting(ExecutionContext *execution_context) override
std::string m_module_name
OptionGroupOptions m_all_options
Target::StopHookSP m_stop_hook_sp
void IOHandlerActivated(IOHandler &io_handler, bool interactive) override
CommandObjectTargetStopHookAdd(CommandInterpreter &interpreter)
void IOHandlerInputComplete(IOHandler &io_handler, std::string &line) override
Called when a line or lines have been retrieved.
~CommandObjectTargetStopHookAdd() override=default
Options * GetOptions() override
OptionGroupPythonClassWithDict m_python_class_options
void DoExecute(Args &command, CommandReturnObject &result) override
void DoExecute(Args &command, CommandReturnObject &result) override
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
CommandObjectTargetStopHookDelete(CommandInterpreter &interpreter)
~CommandObjectTargetStopHookDelete() override=default
~CommandObjectTargetStopHookEnableDisable() override=default
void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector) override
The default version handles argument definitions that have only one argument type,...
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectTargetStopHookEnableDisable(CommandInterpreter &interpreter, bool enable, const char *name, const char *help, const char *syntax)
~CommandOptions() override=default
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
void OptionParsingStarting(ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectTargetStopHookList() override=default
Options * GetOptions() override
CommandObjectTargetStopHookList(CommandInterpreter &interpreter)
bool AddSymbolsForUUID(CommandReturnObject &result, bool &flush)
bool DownloadObjectAndSymbolFile(ModuleSpec &module_spec, CommandReturnObject &result, bool &flush)
bool AddSymbolsForStack(CommandReturnObject &result, bool &flush)
OptionGroupBoolean m_current_stack_option
OptionGroupBoolean m_current_frame_option
CommandObjectTargetSymbolsAdd(CommandInterpreter &interpreter)
bool AddSymbolsForFrame(CommandReturnObject &result, bool &flush)
OptionGroupOptions m_option_group
~CommandObjectTargetSymbolsAdd() override=default
Options * GetOptions() override
void DoExecute(Args &args, CommandReturnObject &result) override
OptionGroupFile m_file_option
OptionGroupUUID m_uuid_option_group
bool AddModuleSymbols(Target *target, ModuleSpec &module_spec, bool &flush, CommandReturnObject &result)
bool AddSymbolsForFile(CommandReturnObject &result, bool &flush)
const CommandObjectTargetSymbols & operator=(const CommandObjectTargetSymbols &)=delete
CommandObjectTargetSymbols(CommandInterpreter &interpreter)
~CommandObjectTargetSymbols() override=default
CommandObjectTargetSymbols(const CommandObjectTargetSymbols &)=delete
OptionGroupFormat m_option_format
void DumpGlobalVariableList(const ExecutionContext &exe_ctx, const SymbolContext &sc, const VariableList &variable_list, CommandReturnObject &result)
void DumpValueObject(Stream &s, VariableSP &var_sp, ValueObjectSP &valobj_sp, const char *root_name)
static size_t GetVariableCallback(void *baton, const char *name, VariableList &variable_list)
static const uint32_t SHORT_OPTION_SHLB
CommandObjectTargetVariable(CommandInterpreter &interpreter)
OptionGroupFileList m_option_shared_libraries
void DoExecute(Args &args, CommandReturnObject &result) override
Options * GetOptions() override
OptionGroupFileList m_option_compile_units
static const uint32_t SHORT_OPTION_FILE
OptionGroupVariable m_option_variable
OptionGroupValueObjectDisplay m_varobj_options
OptionGroupOptions m_option_group
~CommandObjectTargetVariable() override=default
~OptionGroupDependents() override=default
OptionGroupDependents()=default
LoadDependentFiles m_load_dependent_files
OptionGroupDependents(const OptionGroupDependents &)=delete
const OptionGroupDependents & operator=(const OptionGroupDependents &)=delete
void OptionParsingStarting(ExecutionContext *execution_context) override
Status SetOptionValue(uint32_t, const char *, ExecutionContext *)=delete
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_value, ExecutionContext *execution_context) override
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
virtual lldb::addr_t FixCodeAddress(lldb::addr_t pc)
Some targets might use bits in a code address to indicate a mode switch.
A section + offset based address class.
lldb::addr_t GetLoadAddress(Target *target) const
Get the load address.
bool SetLoadAddress(lldb::addr_t load_addr, Target *target, bool allow_section_end=false)
Set the address to represent load_addr.
@ DumpStyleFileAddress
Display as the file address (if any).
@ DumpStyleSectionNameOffset
Display as the section name + offset.
@ DumpStyleDetailedSymbolContext
Detailed symbol context information for an address for all symbol context members.
@ DumpStyleInvalid
Invalid dump style.
@ DumpStyleModuleWithFileAddress
Display as the file address with the module name prepended (if any).
@ DumpStyleResolvedDescription
Display the details about what an address resolves to.
bool Dump(Stream *s, ExecutionContextScope *exe_scope, DumpStyle style, DumpStyle fallback_style=DumpStyleInvalid, uint32_t addr_byte_size=UINT32_MAX, bool all_ranges=false, std::optional< Stream::HighlightSettings > settings=std::nullopt) const
Dump a description of this object to a Stream.
lldb::ModuleSP GetModule() const
Get accessor for the module for this address.
lldb::addr_t GetFileAddress() const
Get the file address.
bool IsValid() const
Check if the object state is valid.
An architecture specification class.
uint32_t GetAddressByteSize() const
Returns the size in bytes of an address of the current architecture.
bool IsValid() const
Tests if this ArchSpec is valid.
void DumpTriple(llvm::raw_ostream &s) const
const char * GetArchitectureName() const
Returns a static string representing the current architecture.
A command line argument class.
void Shift()
Shifts the first argument C string value of the array off the argument array.
size_t GetArgumentCount() const
Gets the number of arguments left in this command object.
llvm::ArrayRef< ArgEntry > entries() const
const char * GetArgumentAtIndex(size_t idx) const
Gets the NULL terminated C string argument pointer for the argument at index idx.
static bool InvokeCommonCompletionCallbacks(CommandInterpreter &interpreter, uint32_t completion_mask, lldb_private::CompletionRequest &request, SearchFilter *searcher)
bool Confirm(llvm::StringRef message, bool default_answer)
ExecutionContext GetExecutionContext() const
CommandObjectMultiwordTarget(CommandInterpreter &interpreter)
~CommandObjectMultiwordTarget() override
bool LoadSubCommand(llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj) override
CommandObjectMultiword(CommandInterpreter &interpreter, const char *name, const char *help=nullptr, const char *syntax=nullptr, uint32_t flags=0)
friend class CommandInterpreter
CommandObjectParsed(CommandInterpreter &interpreter, const char *name, const char *help=nullptr, const char *syntax=nullptr, uint32_t flags=0)
std::vector< CommandArgumentData > CommandArgumentEntry
virtual void SetHelpLong(llvm::StringRef str)
void AddSimpleArgumentList(lldb::CommandArgumentType arg_type, ArgumentRepetitionType repetition_type=eArgRepeatPlain)
ExecutionContext m_exe_ctx
std::vector< CommandArgumentEntry > m_arguments
CommandInterpreter & GetCommandInterpreter()
CommandInterpreter & m_interpreter
virtual void HandleArgumentCompletion(CompletionRequest &request, OptionElementVector &opt_element_vector)
The default version handles argument definitions that have only one argument type,...
void AppendMessage(llvm::StringRef in_string)
void AppendError(llvm::StringRef in_string)
const ValueObjectList & GetValueObjectList() const
void AppendWarningWithFormatv(const char *format, Args &&...args)
Stream & GetErrorStream()
void SetStatus(lldb::ReturnStatus status)
void SetError(Status error)
void AppendErrorWithFormat(const char *format,...) __attribute__((format(printf
void void AppendMessageWithFormatv(const char *format, Args &&...args)
lldb::ReturnStatus GetStatus() const
void AppendWarning(llvm::StringRef in_string)
void AppendErrorWithFormatv(const char *format, Args &&...args)
Stream & GetOutputStream()
A class that describes a compilation unit.
lldb::VariableListSP GetVariableList(bool can_create)
Get the variable list for a compile unit.
const FileSpec & GetPrimaryFile() const
Return the primary source spec associated with this compile unit.
"lldb/Utility/ArgCompletionRequest.h"
void TryCompleteCurrentArg(llvm::StringRef completion, llvm::StringRef description="")
Adds a possible completion string if the completion would complete the current argument.
size_t GetCursorIndex() const
A uniqued constant string class.
void Dump(Stream *s, const char *value_if_empty=nullptr) const
Dump the object description to a stream.
bool IsEmpty() const
Test for empty string.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
const char * GetCString() const
Get the string value as a C string.
const char * AsCString(const char *value_if_empty) const
Get the string value as a C string.
A class to manage flag bits.
TargetList & GetTargetList()
Get accessor for the target list.
llvm::StringRef GetRegexMatchAnsiSuffix() const
Target & GetDummyTarget()
llvm::StringRef GetRegexMatchAnsiPrefix() const
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
DumpValueObjectOptions & SetRootValueObjectName(const char *name=nullptr)
DumpValueObjectOptions & SetFormat(lldb::Format format=lldb::eFormatDefault)
A class that measures elapsed time in an exception safe way.
"lldb/Target/ExecutionContextScope.h" Inherit from this if your object can reconstruct its execution ...
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
ExecutionContextScope * GetBestExecutionContextScope() const
Target * GetTargetPtr() const
Returns a pointer to the target object.
const FileSpec & GetFileSpecAtIndex(size_t idx) const
Get file at index.
size_t GetSize() const
Get the number of files in the file list.
void SetFile(llvm::StringRef path, Style style)
Change the file specified with a new path.
void SetDirectory(ConstString directory)
Directory string set accessor.
const ConstString & GetFilename() const
Filename string const get accessor.
const ConstString & GetDirectory() const
Directory string const get accessor.
ConstString GetFileNameStrippingExtension() const
Return the filename without the extension part.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
void Dump(llvm::raw_ostream &s) const
Dump this object to a Stream.
llvm::StringRef GetFileNameExtension() const
Extract the extension of the file.
void SetFilename(ConstString filename)
Filename string set accessor.
bool ResolveExecutableLocation(FileSpec &file_spec)
Call into the Host to see if it can help find the file.
bool Exists(const FileSpec &file_spec) const
Returns whether the given file exists.
int Open(const char *path, int flags, int mode=0600)
Wraps open in a platform-independent way.
static FileSystem & Instance()
void Resolve(llvm::SmallVectorImpl< char > &path, bool force_make_absolute=false)
Resolve path to make it canonical.
IOHandlerDelegateMultiline(llvm::StringRef end_line, Completion completion=Completion::None)
A delegate class for use with IOHandler subclasses.
lldb::LockableStreamFileSP GetErrorStreamFileSP()
lldb::LockableStreamFileSP GetOutputStreamFileSP()
void GetDescription(Stream *s, Target *target, lldb::DescriptionLevel level)
A collection class for Module objects.
void FindFunctions(ConstString name, lldb::FunctionNameType name_type_mask, const ModuleFunctionSearchOptions &options, SymbolContextList &sc_list) const
ModuleIterableNoLocking ModulesNoLocking() const
static bool ModuleIsInCache(const Module *module_ptr)
void FindGlobalVariables(ConstString name, size_t max_matches, VariableList &variable_list) const
Find global and static variables by name.
std::recursive_mutex & GetMutex() const
lldb::ModuleSP FindFirstModule(const ModuleSpec &module_spec) const
Finds the first module whose file specification matches module_spec.
lldb::ModuleSP GetModuleAtIndexUnlocked(size_t idx) const
Get the module shared pointer for the module at index idx without acquiring the ModuleList mutex.
void FindCompileUnits(const FileSpec &path, SymbolContextList &sc_list) const
Find compile units by partial or full path.
bool AppendIfNeeded(const lldb::ModuleSP &new_module, bool notify=true)
Append a module to the module list, if it is not already there.
Module * GetModulePointerAtIndex(size_t idx) const
Get the module pointer for the module at index idx.
void FindModules(const ModuleSpec &module_spec, ModuleList &matching_module_list) const
Finds modules whose file specification matches module_spec.
lldb::ModuleSP GetModuleAtIndex(size_t idx) const
Get the module shared pointer for the module at index idx.
void Append(const lldb::ModuleSP &module_sp, bool notify=true)
Append a module to the module list.
static size_t RemoveOrphanSharedModules(bool mandatory)
static void FindSharedModules(const ModuleSpec &module_spec, ModuleList &matching_module_list)
bool LoadScriptingResourcesInTarget(Target *target, std::list< Status > &errors, bool continue_on_error=true)
ModuleIterable Modules() const
size_t GetSize() const
Gets the size of the module list.
bool GetModuleSpecAtIndex(size_t i, ModuleSpec &module_spec) const
bool FindMatchingModuleSpec(const ModuleSpec &module_spec, ModuleSpec &match_module_spec) const
FileSpec & GetPlatformFileSpec()
ArchSpec & GetArchitecture()
FileSpec * GetFileSpecPtr()
FileSpec & GetSymbolFileSpec()
A class that describes an executable image and its associated object and symbol files.
const lldb_private::UUID & GetUUID()
Get a reference to the UUID value contained in this object.
virtual SymbolFile * GetSymbolFile(bool can_create=true, Stream *feedback_strm=nullptr)
Get the module's symbol file.
static Module * GetAllocatedModuleAtIndex(size_t idx)
static std::recursive_mutex & GetAllocationModuleCollectionMutex()
bool ResolveFileAddress(lldb::addr_t vm_addr, Address &so_addr)
Symtab * GetSymtab(bool can_create=true)
Get the module's symbol table.
bool MatchesModuleSpec(const ModuleSpec &module_ref)
static size_t GetNumberAllocatedModules()
const ArchSpec & GetArchitecture() const
Get const accessor for the module architecture.
std::string GetSpecificationDescription() const
Get the module path and object name.
const FileSpec & GetFileSpec() const
Get const accessor for the module file specification.
const llvm::sys::TimePoint & GetModificationTime() const
A plug-in interface definition class for object file parsers.
virtual void Dump(Stream *s)=0
Dump a description of this object to a Stream.
virtual std::vector< LoadableData > GetLoadableData(Target &target)
Loads this objfile to memory.
virtual lldb_private::Address GetEntryPointAddress()
Returns the address of the Entry Point in this object file - if the object file doesn't have an entry...
virtual FileSpec & GetFileSpec()
Get accessor to the object file specification.
static ModuleSpecList GetModuleSpecifications(const FileSpec &file, lldb::offset_t file_offset, lldb::offset_t file_size, lldb::DataExtractorSP=lldb::DataExtractorSP())
virtual lldb_private::Address GetBaseAddress()
Returns base address of this object file.
A command line option parsing protocol class.
std::vector< Option > m_getopt_table
void Insert(llvm::StringRef path, llvm::StringRef replacement, uint32_t insert_idx, bool notify)
void Append(llvm::StringRef path, llvm::StringRef replacement, bool notify)
bool RemapPath(ConstString path, ConstString &new_path) const
bool GetPathsAtIndex(uint32_t idx, ConstString &path, ConstString &new_path) const
void Dump(Stream *s, int pair_index=-1)
static bool DownloadObjectAndSymbolFile(ModuleSpec &module_spec, Status &error, bool force_lookup=true, bool copy_executable=true)
void SetExecutableFile(const FileSpec &exe_file, bool add_exe_file_as_first_arg)
A plug-in interface definition class for debugging a process.
ThreadList & GetThreadList()
void Flush()
Flush all data in the process.
lldb::StateType GetState()
Get accessor for the current process state.
const lldb::ABISP & GetABI()
bool IsValid() const
Test if this object contains a valid regular expression.
virtual lldb::ScriptedFrameProviderInterfaceSP CreateScriptedFrameProviderInterface()
lldb::SectionSP FindSectionByName(ConstString section_dstr) const
void Dump(llvm::raw_ostream &s, unsigned indent, Target *target, bool show_header, uint32_t depth) const
This base class provides an interface to stack frames.
virtual const SymbolContext & GetSymbolContext(lldb::SymbolContextItem resolve_scope)
Provide a SymbolContext for this StackFrame's current pc value.
virtual uint32_t GetFrameIndex() const
Query this frame to find what frame it is in this Thread's StackFrameList.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
static Status static Status FromErrorStringWithFormatv(const char *format, Args &&...args)
const char * GetData() const
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
void Format(const char *format, Args &&... args)
Forwards the arguments to llvm::formatv and writes to the stream.
llvm::raw_ostream & AsRawOstream()
Returns a raw_ostream that forwards the data to this Stream object.
size_t Indent(llvm::StringRef s="")
Indent the current line in the stream.
size_t Printf(const char *format,...) __attribute__((format(printf
Output printf formatted output to the stream.
size_t PutCString(llvm::StringRef cstr)
Output a C string to the stream.
void SetIndentLevel(unsigned level)
Set the current indentation level.
void PutCStringColorHighlighted(llvm::StringRef text, std::optional< HighlightSettings > settings=std::nullopt)
Output a C string to the stream with color highlighting.
size_t EOL()
Output and End of Line character to the stream.
void IndentLess(unsigned amount=2)
Decrement the current indentation level.
void IndentMore(unsigned amount=2)
Increment the current indentation level.
unsigned GetIndentLevel() const
Get the current indentation level.
void AddItem(const ObjectSP &item)
bool ForEach(std::function< bool(Object *object)> const &foreach_callback) const
bool GetValueForKeyAsInteger(llvm::StringRef key, IntType &result) const
bool GetValueForKeyAsString(llvm::StringRef key, llvm::StringRef &result) const
bool GetValueForKeyAsArray(llvm::StringRef key, Array *&result) const
Dictionary * GetAsDictionary()
void Dump(lldb_private::Stream &s, bool pretty_print=true) const
Defines a list of symbol context objects.
uint32_t GetSize() const
Get accessor for a symbol context list size.
void Append(const SymbolContext &sc)
Append a new symbol context to the list.
@ eClassOrNamespaceSpecified
Defines a symbol context baton that can be handed other debug core functions.
Function * function
The Function for a given query.
void SortTypeList(TypeMap &type_map, TypeList &type_list) const
Sorts the types in TypeMap according to SymbolContext to TypeList.
lldb::ModuleSP module_sp
The Module for a given query.
CompileUnit * comp_unit
The CompileUnit for a given query.
Symbol * symbol
The Symbol for a given query.
Provides public interface for all SymbolFiles.
virtual ObjectFile * GetObjectFile()=0
bool ValueIsAddress() const
bool GetByteSizeIsValid() const
Address & GetAddressRef()
lldb::addr_t GetByteSize() const
ConstString GetDisplayName() const
uint64_t GetRawValue() const
Get the raw value of the symbol from the symbol table.
Symbol * SymbolAtIndex(size_t idx)
uint32_t AppendSymbolIndexesWithName(ConstString symbol_name, std::vector< uint32_t > &matches)
uint32_t AppendSymbolIndexesMatchingRegExAndType(const RegularExpression ®ex, lldb::SymbolType symbol_type, std::vector< uint32_t > &indexes, Mangled::NamePreference name_preference=Mangled::ePreferDemangled)
lldb::TargetSP GetTargetAtIndex(uint32_t index) const
Status CreateTarget(Debugger &debugger, llvm::StringRef user_exe_path, llvm::StringRef triple_str, LoadDependentFiles get_dependent_modules, const OptionGroupPlatform *platform_options, lldb::TargetSP &target_sp)
Create a new Target.
void SetSelectedTarget(uint32_t index)
bool DeleteTarget(lldb::TargetSP &target_sp)
Delete a Target object from the list.
lldb::TargetSP GetSelectedTarget()
size_t GetNumTargets() const
bool GetUserSpecifiedTrapHandlerNames(Args &args) const
Environment GetEnvironment() const
void SetActionFromStrings(const std::vector< std::string > &strings)
Populate the command list from a vector of individual command strings.
void SetActionFromString(const std::string &strings)
void SetActionFromStrings(const std::vector< std::string > &strings)
Status SetScriptCallback(std::string class_name, StructuredData::ObjectSP extra_args_sp)
void ModulesDidLoad(ModuleList &module_list)
This call may preload module symbols, and may do so in parallel depending on the following target set...
llvm::Expected< uint32_t > AddScriptedFrameProviderDescriptor(const ScriptedFrameProviderDescriptor &descriptor)
Add or update a scripted frame provider descriptor for this target.
Module * GetExecutableModulePointer()
bool RemoveHookByID(lldb::user_id_t uid)
PathMappingList & GetImageSearchPathList()
size_t GetNumHooks() const
std::shared_ptr< StopHook > StopHookSP
void SymbolsDidLoad(ModuleList &module_list)
const std::vector< StopHookSP > GetStopHooks(bool internal=false) const
const llvm::MapVector< uint32_t, ScriptedFrameProviderDescriptor > & GetScriptedFrameProviderDescriptors() const
Get all scripted frame provider descriptors for this target.
bool RemoveScriptedFrameProviderDescriptor(uint32_t id)
Remove a scripted frame provider descriptor by id.
HookSP CreateHook(Hook::HookKind kind)
void DumpSectionLoadList(Stream &s)
bool SetHookEnabledStateByID(lldb::user_id_t uid, bool enabled)
const lldb::ProcessSP & GetProcessSP() const
lldb::ModuleSP GetOrCreateModule(const ModuleSpec &module_spec, bool notify, Status *error_ptr=nullptr)
Find a binary on the system and return its Module, or return an existing Module that is already in th...
void UndoCreateStopHook(lldb::user_id_t uid)
If you tried to create a stop hook, and that failed, call this to remove the stop hook,...
bool ResolveLoadAddress(lldb::addr_t load_addr, Address &so_addr, uint32_t stop_id=SectionLoadHistory::eStopIDNow, bool allow_section_end=false)
HookSP GetHookByID(lldb::user_id_t uid)
bool SetStopHookActiveStateByID(lldb::user_id_t uid, bool active_state)
void SetAllStopHooksActiveState(bool active_state)
StopHookSP CreateStopHook(StopHook::StopHookKind kind, bool internal=false)
Add an empty stop hook to the Target's stop hook list, and returns a shared pointer to the new hook.
void SetAllHooksEnabledState(bool enabled)
void RemoveAllStopHooks()
void UndoCreateHook(lldb::user_id_t uid)
Removes the most recently created hook.
HookSP GetHookAtIndex(size_t index)
lldb::PlatformSP GetPlatform()
const ModuleList & GetImages() const
Get accessor for the images for this process.
const ArchSpec & GetArchitecture() const
const std::string & GetLabel() const
void ClearScriptedFrameProviderDescriptors()
Clear all scripted frame provider descriptors for this target.
std::shared_ptr< Hook > HookSP
lldb::ProcessSP CalculateProcess() override
bool SetSectionLoadAddress(const lldb::SectionSP §ion, lldb::addr_t load_addr, bool warn_multiple=false)
bool RemoveStopHookByID(lldb::user_id_t uid)
lldb::ThreadSP GetSelectedThread()
uint32_t GetSize(bool can_update=true)
lldb::ThreadSP GetThreadAtIndex(uint32_t idx, bool can_update=true)
void SetIndex(uint32_t index)
void SetName(llvm::StringRef name)
void SetTID(lldb::tid_t tid)
void SetQueueName(llvm::StringRef queue_name)
lldb::TypeSP GetTypeAtIndex(uint32_t idx)
A class that contains all state required for type lookups.
This class tracks the state and results of a TypeQuery.
void Dump(Stream &s) const
std::string GetAsString(llvm::StringRef separator="-") const
lldb::FuncUnwindersSP GetFuncUnwindersContainingAddress(const Address &addr, const SymbolContext &sc)
lldb::FuncUnwindersSP GetUncachedFuncUnwindersContainingAddress(const Address &addr, const SymbolContext &sc)
A collection of ValueObject values that.
void Append(const lldb::ValueObjectSP &val_obj_sp)
lldb::ValueObjectSP GetValueObjectAtIndex(size_t idx)
static lldb::ValueObjectSP Create(ExecutionContextScope *exe_scope, const lldb::VariableSP &var_sp)
lldb::VariableSP GetVariableAtIndex(size_t idx) const
static Status GetValuesForVariableExpressionPath(llvm::StringRef variable_expr_path, ExecutionContextScope *scope, GetVariableCallback callback, void *baton, VariableList &variable_list, ValueObjectList &valobj_list)
#define LLDB_OPT_SET_FROM_TO(A, B)
#define LLDB_INVALID_LINE_NUMBER
#define LLDB_INVALID_THREAD_ID
#define LLDB_INVALID_INDEX32
#define LLDB_INVALID_ADDRESS
#define LLDB_INVALID_PROCESS_ID
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
std::vector< OptionArgElement > OptionElementVector
bool StateIsStoppedState(lldb::StateType state, bool must_exist)
Check if a state represents a state where the process or thread is stopped.
void DumpAddress(llvm::raw_ostream &s, uint64_t addr, uint32_t addr_size, const char *prefix=nullptr, const char *suffix=nullptr)
Output an address value to this stream.
const char * StateAsCString(lldb::StateType state)
Converts a StateType to a C string.
std::string toString(FormatterBytecode::OpCodes op)
std::shared_ptr< lldb_private::TypeSystem > TypeSystemSP
std::shared_ptr< lldb_private::ABI > ABISP
std::shared_ptr< lldb_private::StackFrame > StackFrameSP
DescriptionLevel
Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls.
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::ScriptedMetadata > ScriptedMetadataSP
std::shared_ptr< lldb_private::CommandObject > CommandObjectSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
Format
Display format definitions.
std::shared_ptr< lldb_private::Platform > PlatformSP
StateType
Process and Thread States.
std::shared_ptr< lldb_private::FuncUnwinders > FuncUnwindersSP
std::shared_ptr< lldb_private::Type > TypeSP
std::shared_ptr< lldb_private::Process > ProcessSP
@ eReturnStatusSuccessFinishResult
@ eReturnStatusSuccessFinishNoResult
@ eArgTypeUnsignedInteger
std::shared_ptr< lldb_private::VariableList > VariableListSP
std::shared_ptr< lldb_private::UnwindPlan > UnwindPlanSP
std::shared_ptr< lldb_private::Variable > VariableSP
std::shared_ptr< lldb_private::ScriptedFrameProviderInterface > ScriptedFrameProviderInterfaceSP
@ eValueTypeVariableGlobal
globals variable
@ eValueTypeVariableLocal
function local variables
@ eValueTypeVariableArgument
function argument variables
@ eValueTypeVariableStatic
static variable
@ eValueTypeVariableThreadLocal
thread local storage variable
std::shared_ptr< lldb_private::LockableStreamFile > LockableStreamFileSP
std::shared_ptr< lldb_private::Section > SectionSP
std::shared_ptr< lldb_private::Target > TargetSP
std::shared_ptr< lldb_private::RegisterContext > RegisterContextSP
std::shared_ptr< lldb_private::Module > ModuleSP
Used to build individual command argument lists.
ArgumentRepetitionType arg_repetition
lldb::CommandArgumentType arg_type
Options used by Module::FindFunctions.
bool include_inlines
Include inlined functions.
bool include_symbols
Include the symbol table.
static int64_t ToOptionEnum(llvm::StringRef s, const OptionEnumValues &enum_values, int32_t fail_value, Status &error)
static lldb::addr_t ToAddress(const ExecutionContext *exe_ctx, llvm::StringRef s, lldb::addr_t fail_value, Status *error_ptr)
Try to parse an address.
static bool ToBoolean(llvm::StringRef s, bool fail_value, bool *success_ptr)
This struct contains the metadata needed to instantiate a frame provider and optional filters to cont...
void Dump(Stream *s) const
Dump a description of this descriptor to the given stream.
lldb::ScriptedFrameProviderInterfaceSP interface_sp
Interface for calling static methods on the provider class.
Struct to store information for color highlighting in the stream.