58#include "llvm/ADT/STLExtras.h"
59#include "llvm/Support/Compiler.h"
60#include "llvm/Support/DJB.h"
61#include "llvm/Support/FileSystem.h"
62#include "llvm/Support/FormatVariadic.h"
63#include "llvm/Support/JSON.h"
64#include "llvm/Support/Signals.h"
65#include "llvm/Support/raw_ostream.h"
100 if (g_module_collection ==
nullptr)
103 return *g_module_collection;
112 static std::recursive_mutex *g_module_collection_mutex =
nullptr;
113 if (g_module_collection_mutex ==
nullptr)
114 g_module_collection_mutex =
new std::recursive_mutex;
115 return *g_module_collection_mutex;
119 std::lock_guard<std::recursive_mutex> guard(
125 std::lock_guard<std::recursive_mutex> guard(
128 if (idx < modules.size())
134 : m_unwind_table(*this), m_file_has_changed(false),
135 m_first_file_changed_log(false) {
138 std::lock_guard<std::recursive_mutex> guard(
145 LLDB_LOGF(log,
"%p Module::Module((%s) '%s%s%s%s')",
146 static_cast<void *
>(
this),
153 auto data_sp = module_spec.
GetData();
156 file_size = data_sp->GetByteSize();
162 module_spec.
GetFileSpec(), 0, file_size, modules_specs, data_sp) == 0)
174 matching_module_spec)) {
176 LLDB_LOGF(log,
"Found local object file but the specs didn't match");
184 if (
auto module_spec_data_sp = module_spec.
GetData()) {
238 const llvm::sys::TimePoint<> &object_mod_time)
239 : m_mod_time(
FileSystem::Instance().GetModificationTime(file_spec)),
240 m_arch(arch), m_file(file_spec), m_object_name(object_name),
241 m_object_offset(object_offset), m_object_mod_time(object_mod_time),
242 m_unwind_table(*this), m_file_has_changed(false),
243 m_first_file_changed_log(false) {
246 std::lock_guard<std::recursive_mutex> guard(
253 LLDB_LOGF(log,
"%p Module::Module((%s) '%s%s%s%s')",
260 : m_unwind_table(*this), m_file_has_changed(false),
261 m_first_file_changed_log(false) {
262 std::lock_guard<std::recursive_mutex> guard(
270 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
273 std::lock_guard<std::recursive_mutex> guard(
276 ModuleCollection::iterator end = modules.end();
277 ModuleCollection::iterator pos = std::find(modules.begin(), end,
this);
283 LLDB_LOGF(log,
"%p Module::~Module((%s) '%s%s%s%s')",
299 size_t size_to_read) {
301 error.SetErrorString(
"object file already exists");
303 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
306 std::shared_ptr<DataBufferHeap> data_sp =
307 std::make_shared<DataBufferHeap>(size_to_read, 0);
309 const size_t bytes_read =
310 process_sp->ReadMemory(header_addr, data_sp->GetBytes(),
311 data_sp->GetByteSize(), readmem_error);
312 if (bytes_read < size_to_read)
313 data_sp->SetByteSize(bytes_read);
314 if (data_sp->GetByteSize() > 0) {
316 header_addr, data_sp);
319 s.
Printf(
"0x%16.16" PRIx64, header_addr);
333 error.SetErrorString(
"unable to find suitable object file plug-in");
336 error.SetErrorStringWithFormat(
"unable to read header from memory: %s",
340 error.SetErrorString(
"invalid process");
348 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
352 if (obj_file !=
nullptr) {
362 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
367 lldbassert(0 &&
"Attempting to overwrite the existing module UUID");
371llvm::Expected<TypeSystemSP>
382 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
384 if (num_comp_units == 0)
389 for (
size_t cu_idx = 0; cu_idx < num_comp_units; cu_idx++) {
421 s->
Printf(
", Module{%p}",
static_cast<void *
>(
this));
425 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
427 return symbols->GetNumCompileUnits();
432 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
436 if (index < num_comp_units) {
438 cu_sp = symbols->GetCompileUnitAtIndex(index);
444 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
452 const Address &so_addr, lldb::SymbolContextItem resolve_scope,
454 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
455 uint32_t resolved_flags = 0;
465 if (section_sp && section_sp->GetModule().get() ==
this) {
469 resolved_flags |= eSymbolContextModule;
473 return resolved_flags;
477 if (resolve_scope & eSymbolContextCompUnit ||
478 resolve_scope & eSymbolContextFunction ||
479 resolve_scope & eSymbolContextBlock ||
480 resolve_scope & eSymbolContextLineEntry ||
481 resolve_scope & eSymbolContextVariable) {
489 if (resolve_scope & eSymbolContextSymbol &&
490 !(resolved_flags & eSymbolContextSymbol)) {
493 Symbol *matching_symbol =
nullptr;
497 [&matching_symbol](
Symbol *symbol) ->
bool {
498 if (symbol->GetType() != eSymbolTypeInvalid) {
499 matching_symbol = symbol;
504 sc.
symbol = matching_symbol;
505 if (!sc.
symbol && resolve_scope & eSymbolContextFunction &&
506 !(resolved_flags & eSymbolContextFunction)) {
507 bool verify_unique =
false;
512 obj_file->ResolveSymbolForAddress(so_addr, verify_unique);
523 if (symtab_objfile && symtab_objfile->
IsStripped()) {
525 if (symfile_objfile != symtab_objfile) {
527 if (symfile_symtab) {
538 resolved_flags |= eSymbolContextSymbol;
546 if (resolve_scope & eSymbolContextSymbol &&
547 !(resolved_flags & eSymbolContextSymbol) && resolve_tail_call_address &&
549 Address previous_addr = so_addr;
550 previous_addr.
Slide(-1);
552 bool do_resolve_tail_call_address =
false;
554 previous_addr, resolve_scope, sc, do_resolve_tail_call_address);
555 if (flags & eSymbolContextSymbol) {
557 if (sc.
GetAddressRange(eSymbolContextFunction | eSymbolContextSymbol, 0,
558 false, addr_range)) {
569 resolved_flags |= flags;
579 return resolved_flags;
583 const char *file_path, uint32_t line,
bool check_inlines,
587 resolve_scope, sc_list);
591 const FileSpec &file_spec, uint32_t line,
bool check_inlines,
593 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
595 "check_inlines = %s, resolve_scope = 0x%8.8x)",
596 file_spec.
GetPath().c_str(), line,
597 check_inlines ?
"yes" :
"no", resolve_scope);
599 const uint32_t initial_count = sc_list.
GetSize();
604 check_inlines,
false);
606 symbols->ResolveSymbolContext(location_spec, resolve_scope, sc_list);
609 return sc_list.
GetSize() - initial_count;
616 symbols->FindGlobalVariables(name, parent_decl_ctx, max_matches, variables);
631 for (
size_t i = 0; i < num_compile_units; ++i) {
641 FunctionNameType name_type_mask,
643 : m_name(name), m_lookup_name(), m_language(language) {
645 llvm::StringRef basename;
646 llvm::StringRef context;
648 if (name_type_mask & eFunctionNameTypeAuto) {
650 m_name_type_mask = eFunctionNameTypeFull;
654 m_name_type_mask = eFunctionNameTypeFull;
656 m_name_type_mask = eFunctionNameTypeFull;
661 m_name_type_mask |= eFunctionNameTypeSelector;
664 basename = cpp_method.GetBasename();
665 if (basename.empty()) {
668 m_name_type_mask |= (eFunctionNameTypeMethod | eFunctionNameTypeBase);
670 m_name_type_mask |= eFunctionNameTypeFull;
672 m_name_type_mask |= (eFunctionNameTypeMethod | eFunctionNameTypeBase);
676 m_name_type_mask = name_type_mask;
677 if (name_type_mask & eFunctionNameTypeMethod ||
678 name_type_mask & eFunctionNameTypeBase) {
682 if (cpp_method.IsValid()) {
683 basename = cpp_method.GetBasename();
685 if (!cpp_method.GetQualifiers().empty()) {
688 m_name_type_mask &= ~(eFunctionNameTypeBase);
689 if (m_name_type_mask == eFunctionNameTypeNone)
701 if (name_type_mask & eFunctionNameTypeSelector) {
703 m_name_type_mask &= ~(eFunctionNameTypeSelector);
704 if (m_name_type_mask == eFunctionNameTypeNone)
711 if (basename.empty()) {
712 if (name_type_mask & eFunctionNameTypeFull &&
715 basename = cpp_method.GetBasename();
716 if (basename.empty())
723 if (!basename.empty()) {
728 m_lookup_name.SetString(basename);
729 m_match_name_after_lookup =
true;
733 m_lookup_name = name;
734 m_match_name_after_lookup =
false;
745 if (
m_name == function_name)
753 const bool function_name_may_be_mangled =
755 ConstString demangled_function_name = function_name;
756 if (function_name_may_be_mangled) {
757 Mangled mangled_function_name(function_name);
765 return language->DemangledNameContainsPath(
m_name, demangled_function_name);
767 llvm::StringRef function_name_ref = demangled_function_name;
768 return function_name_ref.contains(
m_name);
772 size_t start_idx)
const {
773 if (m_match_name_after_lookup && m_name) {
775 size_t i = start_idx;
776 while (i < sc_list.
GetSize()) {
793 if (m_name_type_mask == eFunctionNameTypeFull) {
795 size_t i = start_idx;
796 while (i < sc_list.
GetSize()) {
803 if (mangled_name != m_name && full_name != m_name) {
807 if (cpp_method.
GetBasename().compare(m_name) != 0) {
812 std::string qualified_name;
813 llvm::StringRef anon_prefix(
"(anonymous namespace)");
818 if (qualified_name != m_name.GetCString()) {
836 symbols->FindFunctions(lookup_info, parent_decl_ctx,
841 if (
Symtab *symtab = symbols->GetSymtab()) {
851 FunctionNameType name_type_mask,
854 const size_t old_size = sc_list.
GetSize();
856 FindFunctions(lookup_info, parent_decl_ctx, options, sc_list);
857 if (name_type_mask & eFunctionNameTypeAuto) {
858 const size_t new_size = sc_list.
GetSize();
859 if (old_size < new_size)
860 lookup_info.Prune(sc_list, old_size);
865 FunctionNameType name_type_mask,
868 if (compiler_ctx.empty() ||
876 for (
auto &sc : unfiltered)
877 if (sc.function && compiler_ctx.equals(sc.function->GetCompilerContext()))
884 const size_t start_size = sc_list.
GetSize();
892 Symtab *symtab = symbols->GetSymtab();
894 std::vector<uint32_t> symbol_indexes;
898 const size_t num_matches = symbol_indexes.size();
901 const size_t end_functions_added_index = sc_list.
GetSize();
902 size_t num_functions_added_to_sc_list =
903 end_functions_added_index - start_size;
904 if (num_functions_added_to_sc_list == 0) {
907 for (
size_t i = 0; i < num_matches; ++i) {
915 typedef std::map<lldb::addr_t, uint32_t> FileAddrToIndexMap;
916 FileAddrToIndexMap file_addr_to_index;
917 for (
size_t i = start_size; i < end_functions_added_index; ++i) {
926 FileAddrToIndexMap::const_iterator end = file_addr_to_index.
end();
929 for (
size_t i = start_size; i < num_matches; ++i) {
935 FileAddrToIndexMap::const_iterator pos =
936 file_addr_to_index.find(
941 sc_list[pos->second].symbol = sc.
symbol;
952 const FileSpec &file, uint32_t line,
954 std::vector<Address> &output_local,
955 std::vector<Address> &output_extern) {
968 if (f && f == function)
969 output_local.push_back(addr);
971 output_extern.push_back(addr);
977 symbols->FindTypes(query, results);
985 if (requestors.empty())
988 for (
auto debugger_sp : requestors) {
989 if (!debugger_sp->InterruptRequested())
991 if (debugger_sp->GetTargetList()
992 .AnyTargetContainsModule(module))
993 interruptors.push_back(debugger_sp);
1000 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1004 if (!interruptors.empty()) {
1005 for (
auto debugger_sp : interruptors) {
1007 "Interrupted fetching symbols for module {0}",
1008 this->GetFileSpec());
1013 if (obj_file !=
nullptr) {
1027 return symbols->GetSymtab();
1071 s << llvm::formatv(
"({0})", object_name);
1086 std::optional<lldb::user_id_t> debugger_id) {
1093 <<
" was compiled with optimization - stepping may behave "
1094 "oddly; variables may not be available.";
1100 LanguageType language, std::optional<lldb::user_id_t> debugger_id) {
1102 ss <<
"This version of LLDB has no plugin for the language \""
1105 "Inspection of frame variables will be limited.";
1111 const llvm::formatv_object_base &payload) {
1120 strm.
PutCString(
"The debug session should be aborted as the original "
1121 "debug information has been overwritten.");
1152 Log *log,
const llvm::formatv_object_base &payload) {
1158 std::string back_trace;
1159 llvm::raw_string_ostream stream(back_trace);
1160 llvm::sys::PrintStackTrace(stream);
1167 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1191 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1221 ReportError(
"failed to load objfile for {0}\nDebugging will be "
1222 "degraded for this module.",
1235 if (obj_file !=
nullptr)
1246 symbols->SectionFileAddressesChanged();
1264 "Module::FindFirstSymbolWithNameAndType (name = %s, type = %i)",
1267 return symtab->FindFirstSymbolWithNameAndType(
1272 Symtab *symtab, std::vector<uint32_t> &symbol_indexes,
1277 size_t num_indices = symbol_indexes.size();
1278 if (num_indices > 0) {
1281 for (
size_t i = 0; i < num_indices; i++) {
1294 symtab->FindFunctionSymbols(name, name_type_mask, sc_list);
1303 std::vector<uint32_t> symbol_indexes;
1304 symtab->FindAllSymbolsWithNameAndType(name, symbol_type, symbol_indexes);
1315 "Module::FindSymbolsMatchingRegExAndType (regex = %s, type = %i)",
1316 regex.
GetText().str().c_str(), symbol_type);
1318 std::vector<uint32_t> symbol_indexes;
1319 symtab->FindAllSymbolsMatchingRexExAndType(
1321 symbol_indexes, mangling_preference);
1327 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1335 symtab->PreloadSymbols();
1350 if (section_list && symbol_file) {
1373 std::string new_path(file.
GetPath());
1375 if (llvm::StringRef(old_path).starts_with(new_path)) {
1384 for (
size_t idx = num_sections; idx > 0; --idx) {
1387 if (section_sp->GetObjectFile() == obj_file) {
1414 if (sections !=
nullptr) {
1415 size_t num_sections = sections->
GetSize();
1416 for (
size_t sect_idx = 0; sect_idx < num_sections; sect_idx++) {
1428 Stream &feedback_stream) {
1430 error.SetErrorString(
"invalid destination Target");
1435 target->TargetProperties::GetLoadScriptFromSymbolFile();
1447 error.SetErrorString(
"invalid Platform");
1451 FileSpecList file_specs = platform_sp->LocateExecutableScriptingResources(
1452 target, *
this, feedback_stream);
1454 const uint32_t num_specs = file_specs.
GetSize();
1457 if (script_interpreter) {
1458 for (uint32_t i = 0; i < num_specs; ++i) {
1460 if (scripting_fspec &&
1464 "warning: '%s' contains a debug script. To run this script "
1466 "this debug session:\n\n command script import "
1468 "To run all discovered debug scripts in this session:\n\n"
1469 " settings set target.load-script-from-symbol-file "
1471 GetFileSpec().GetFileNameStrippingExtension().GetCString(),
1472 scripting_fspec.
GetPath().c_str());
1485 error.SetErrorString(
"invalid ScriptInterpreter");
1502 bool value_is_offset,
bool &changed) {
1504 if (object_file !=
nullptr) {
1505 changed = object_file->
SetLoadAddress(target, value, value_is_offset);
1546 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1548 new_spec = *remapped;
1555 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1557 return remapped->GetPath();
1562 llvm::StringRef sysroot) {
1563 auto sdk_path_or_err =
1564 HostInfo::GetSDKRoot(HostInfo::SDKOptions{sdk_name.str()});
1566 if (!sdk_path_or_err) {
1568 toString(sdk_path_or_err.takeError()));
1572 auto sdk_path = *sdk_path_or_err;
1573 if (sdk_path.empty())
1586 "module has arch %s, merging/replacing with arch %s",
1588 arch_spec.
GetTriple().getTriple().c_str());
1604 return obj_file->GetVersion();
1605 return llvm::VersionTuple();
1618 std::string identifier;
1619 llvm::raw_string_ostream id_strm(identifier);
1628 return llvm::djbHash(id_strm.str());
1633 llvm::raw_string_ostream strm(key);
1637 strm <<
'-' << llvm::format_hex(
Hash(), 10);
1648 .GetLLDBIndexCachePath()
1650 return g_data_file_cache;
static llvm::raw_ostream & error(Stream &strm)
#define REPORT_INTERRUPTION(debugger,...)
#define LLDB_LOGF(log,...)
std::vector< Module * > ModuleCollection
static ModuleCollection & GetModuleCollection()
static Debugger::DebuggerList DebuggersOwningModuleRequestingInterruption(Module &module)
#define LLDB_SCOPED_TIMER()
#define LLDB_SCOPED_TIMERF(...)
A section + offset based address range class.
Address & GetBaseAddress()
Get accessor for the base address of the range.
lldb::addr_t GetByteSize() const
Get accessor for the byte size of this range.
"lldb/Core/AddressResolverFileLine.h" This class finds address for source file and line.
size_t GetNumberOfAddresses()
virtual void ResolveAddress(SearchFilter &filter)
AddressRange & GetAddressRangeAtIndex(size_t idx)
A section + offset based address class.
bool ResolveAddressUsingFileSections(lldb::addr_t addr, const SectionList *sections)
Resolve a file virtual address using a section list.
lldb::SectionSP GetSection() const
Get const accessor for the section.
Function * CalculateSymbolContextFunction() const
bool Slide(int64_t offset)
lldb::addr_t GetFileAddress() const
Get the file address.
lldb::addr_t GetOffset() const
Get the section relative offset value.
bool IsSectionOffset() const
Check if an address is section offset.
An architecture specification class.
bool IsValid() const
Tests if this ArchSpec is valid.
llvm::Triple & GetTriple()
Architecture triple accessor.
void MergeFrom(const ArchSpec &other)
Merges fields from another ArchSpec into this ArchSpec.
bool IsCompatibleMatch(const ArchSpec &rhs) const
Shorthand for IsMatch(rhs, CompatibleMatch).
const char * GetArchitectureName() const
Returns a static string representing the current architecture.
std::string GetScopeQualifiedName()
llvm::StringRef GetContext()
llvm::StringRef GetBasename()
static bool IsCPPMangledName(llvm::StringRef name)
static bool ExtractContextAndIdentifier(const char *name, llvm::StringRef &context, llvm::StringRef &identifier)
const FileSpec & GetPrimaryFile() const
Return the primary source spec associated with this compile unit.
void ForeachFunction(llvm::function_ref< bool(const lldb::FunctionSP &)> lambda) const
Apply a lambda to each function in this compile unit.
Represents a generic declaration context in a program.
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
bool IsEmpty() const
Test for empty string.
void SetString(llvm::StringRef s)
const char * GetCString() const
Get the string value as a C string.
This class enables data to be cached into a directory using the llvm caching code.
A class to manage flag bits.
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
lldb::ScriptLanguage GetScriptLanguage() const
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
std::vector< lldb::DebuggerSP > DebuggerList
static DebuggerList DebuggersRequestingInterruption()
const FileSpec & GetFileSpecAtIndex(size_t idx) const
Get file at index.
size_t GetSize() const
Get the number of files in the file list.
static bool Match(const FileSpec &pattern, const FileSpec &file)
Match FileSpec pattern against FileSpec file.
const ConstString & GetFilename() const
Filename string const get accessor.
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.
uint64_t GetByteSize(const FileSpec &file_spec) const
Returns the on-disk size of the given file in bytes.
llvm::sys::TimePoint GetModificationTime(const FileSpec &file_spec) const
Returns the modification time of the given file.
static FileSystem & Instance()
A class that describes a function.
const AddressRange & GetAddressRange()
static Language * FindPlugin(lldb::LanguageType language)
static const char * GetNameForLanguageType(lldb::LanguageType language)
static bool LanguageIsC(lldb::LanguageType language)
static bool LanguageIsObjC(lldb::LanguageType language)
void PutCString(const char *cstr)
A class that handles mangled names.
static Mangled::ManglingScheme GetManglingScheme(llvm::StringRef const name)
Try to identify the mangling scheme used.
ConstString GetDemangledName() const
Demangled name get accessor.
static ModuleListProperties & GetGlobalModuleListProperties()
bool FindMatchingModuleSpec(const ModuleSpec &module_spec, ModuleSpec &match_module_spec) const
uint64_t GetObjectOffset() const
ConstString & GetObjectName()
FileSpec & GetPlatformFileSpec()
lldb::DataBufferSP GetData() const
ArchSpec & GetArchitecture()
FileSpec & GetSymbolFileSpec()
llvm::sys::TimePoint & GetObjectModificationTime()
A class that encapsulates name lookup information.
lldb::FunctionNameType GetNameTypeMask() const
ConstString GetLookupName() const
bool NameMatchesLookupInfo(ConstString function_name, lldb::LanguageType language_type=lldb::eLanguageTypeUnknown) const
ConstString m_name
What the user originally typed.
void Prune(SymbolContextList &sc_list, size_t start_idx) const
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.
uint32_t ResolveSymbolContextForFilePath(const char *file_path, uint32_t line, bool check_inlines, lldb::SymbolContextItem resolve_scope, SymbolContextList &sc_list)
Resolve items in the symbol context for a given file and line.
std::atomic< bool > m_did_set_uuid
void ReportWarningOptimization(std::optional< lldb::user_id_t > debugger_id)
std::once_flag m_optimization_warning
PathMappingList m_source_mappings
Module specific source remappings for when you have debug info for a module that doesn't match where ...
llvm::sys::TimePoint m_object_mod_time
virtual ObjectFile * GetObjectFile()
Get the object file representation for the current architecture.
void FindGlobalVariables(ConstString name, const CompilerDeclContext &parent_decl_ctx, size_t max_matches, VariableList &variable_list)
Find global and static variables by name.
void ReportWarning(const char *format, Args &&...args)
FileSpec m_file
The file representation on disk for this module (if there is one).
virtual SymbolFile * GetSymbolFile(bool can_create=true, Stream *feedback_strm=nullptr)
Get the module's symbol file.
static DataFileCache * GetIndexCache()
Get the global index file cache.
std::vector< lldb::SymbolVendorUP > m_old_symfiles
If anyone calls Module::SetSymbolFileFileSpec() and changes the symbol file,.
void ReportWarningUnsupportedLanguage(lldb::LanguageType language, std::optional< lldb::user_id_t > debugger_id)
void FindCompileUnits(const FileSpec &path, SymbolContextList &sc_list)
Find compile units by partial or full path.
ConstString GetObjectName() const
uint32_t Hash()
Get a unique hash for this module.
lldb::ModuleSP CalculateSymbolContextModule() override
std::once_flag m_language_warning
static Module * GetAllocatedModuleAtIndex(size_t idx)
UUID m_uuid
Each module is assumed to have a unique identifier to help match it up to debug symbols.
std::optional< std::string > RemapSourceFile(llvm::StringRef path) const
Remaps a source file given path into new_path.
llvm::sys::TimePoint m_mod_time
The modification time for this module when it was created.
lldb::CompUnitSP GetCompileUnitAtIndex(size_t idx)
uint32_t ResolveSymbolContextForAddress(const Address &so_addr, lldb::SymbolContextItem resolve_scope, SymbolContext &sc, bool resolve_tail_call_address=false)
Resolve the symbol context for the given address.
void SetFileSpecAndObjectName(const FileSpec &file, ConstString object_name)
std::recursive_mutex m_mutex
A mutex to keep this object happy in multi-threaded environments.
static std::recursive_mutex & GetAllocationModuleCollectionMutex()
lldb::DataBufferSP m_data_sp
DataBuffer containing the module image, if it was provided at construction time.
bool SetLoadAddress(Target &target, lldb::addr_t value, bool value_is_offset, bool &changed)
Set the load address for all sections in a module to be the file address plus slide.
void SetSymbolFileFileSpec(const FileSpec &file)
void RegisterXcodeSDK(llvm::StringRef sdk, llvm::StringRef sysroot)
This callback will be called by SymbolFile implementations when parsing a compile unit that contains ...
void FindSymbolsWithNameAndType(ConstString name, lldb::SymbolType symbol_type, SymbolContextList &sc_list)
void CalculateSymbolContext(SymbolContext *sc) override
Reconstruct the object's symbol context into sc.
FileSpec m_symfile_spec
If this path is valid, then this is the file that will be used as the symbol file for this module.
bool ResolveFileAddress(lldb::addr_t vm_addr, Address &so_addr)
ArchSpec m_arch
The architecture for this module.
void ReportError(const char *format, Args &&...args)
const FileSpec & GetPlatformFileSpec() const
Get accessor for the module platform file specification.
lldb::SymbolVendorUP m_symfile_up
A pointer to the symbol vendor for this module.
const Symbol * FindFirstSymbolWithNameAndType(ConstString name, lldb::SymbolType symbol_type=lldb::eSymbolTypeAny)
Find a symbol in the object file's symbol table.
llvm::VersionTuple GetVersion()
void FindAddressesForLine(const lldb::TargetSP target_sp, const FileSpec &file, uint32_t line, Function *function, std::vector< Address > &output_local, std::vector< Address > &output_extern)
Find addresses by file/line.
void FindFunctions(const LookupInfo &lookup_info, const CompilerDeclContext &parent_decl_ctx, const ModuleFunctionSearchOptions &options, SymbolContextList &sc_list)
Find functions by lookup info.
void DumpSymbolContext(Stream *s) override
Dump the object's symbol context to the stream s.
void FindFunctionSymbols(ConstString name, uint32_t name_type_mask, SymbolContextList &sc_list)
Find a function symbols in the object file's symbol table.
size_t GetNumCompileUnits()
Get the number of compile units for this module.
ConstString m_object_name
The name an object within this module that is selected, or empty of the module is represented by m_fi...
void LogMessage(Log *log, const char *format, Args &&...args)
bool MatchesModuleSpec(const ModuleSpec &module_ref)
~Module() override
Destructor.
static size_t GetNumberAllocatedModules()
ObjectFile * GetMemoryObjectFile(const lldb::ProcessSP &process_sp, lldb::addr_t header_addr, Status &error, size_t size_to_read=512)
Load an object file from memory.
bool LoadScriptingResourceInTarget(Target *target, Status &error, Stream &feedback_stream)
TypeSystemMap m_type_system_map
A map of any type systems associated with this module.
void ForEachTypeSystem(llvm::function_ref< bool(lldb::TypeSystemSP)> callback)
Call callback for each TypeSystem in this Module.
lldb::SectionListUP m_sections_up
Unified section list for module that is used by the ObjectFile and ObjectFile instances for the debug...
bool IsExecutable()
Tells whether this module is capable of being the main executable for a process.
FileSpec m_platform_file
The path to the module on the platform on which it is being debugged.
bool MergeArchitecture(const ArchSpec &arch_spec)
Update the ArchSpec to a more specific variant.
bool FileHasChanged() const
const ArchSpec & GetArchitecture() const
Get const accessor for the module architecture.
void LogMessageVerboseBacktrace(Log *log, const char *format, Args &&...args)
bool GetIsDynamicLinkEditor()
std::string GetCacheKey()
Get a unique cache key for the current module.
virtual SectionList * GetSectionList()
Get the unified section list for the module.
llvm::Expected< lldb::TypeSystemSP > GetTypeSystemForLanguage(lldb::LanguageType language)
void Dump(Stream *s)
Dump a description of this object to a Stream.
uint32_t ResolveSymbolContextsForFileSpec(const FileSpec &file_spec, uint32_t line, bool check_inlines, lldb::SymbolContextItem resolve_scope, SymbolContextList &sc_list)
Resolve items in the symbol context for a given file and line.
lldb::ObjectFileSP m_objfile_sp
A shared pointer to the object file parser for this module as it may or may not be shared with the Sy...
void ReportErrorIfModifyDetected(const char *format, Args &&...args)
void FindSymbolsMatchingRegExAndType(const RegularExpression ®ex, lldb::SymbolType symbol_type, SymbolContextList &sc_list, Mangled::NamePreference mangling_preference=Mangled::ePreferDemangled)
std::atomic< bool > m_did_load_symfile
UnwindTable & GetUnwindTable()
Returns a reference to the UnwindTable for this Module.
std::string GetSpecificationDescription() const
Get the module path and object name.
UnwindTable m_unwind_table
Table of FuncUnwinders objects created for this Module's functions.
const FileSpec & GetFileSpec() const
Get const accessor for the module file specification.
bool IsLoadedInTarget(Target *target)
Tells whether this module has been loaded in the target passed in.
void GetDescription(llvm::raw_ostream &s, lldb::DescriptionLevel level=lldb::eDescriptionLevelFull)
void SetUUID(const lldb_private::UUID &uuid)
bool m_first_file_changed_log
void SymbolIndicesToSymbolContextList(Symtab *symtab, std::vector< uint32_t > &symbol_indexes, SymbolContextList &sc_list)
virtual void SectionFileAddressesChanged()
Notify the module that the file addresses for the Sections have been updated.
std::atomic< bool > m_did_load_objfile
bool FindSourceFile(const FileSpec &orig_spec, FileSpec &new_spec) const
Finds a source file given a file spec using the module source path remappings (if any).
void FindTypes(const TypeQuery &query, TypeResults &results)
Find types using a type-matching object that contains all search parameters.
bool SetArchitecture(const ArchSpec &new_arch)
SectionList * GetUnifiedSectionList()
void ParseAllDebugSymbols()
A debugging function that will cause everything in a module to be parsed.
static bool IsPossibleObjCSelector(const char *name)
static bool IsPossibleObjCMethodName(const char *name)
A plug-in interface definition class for object file parsers.
static lldb::ObjectFileSP FindPlugin(const lldb::ModuleSP &module_sp, const FileSpec *file_spec, lldb::offset_t file_offset, lldb::offset_t file_size, lldb::DataBufferSP &data_sp, lldb::offset_t &data_offset)
Find a ObjectFile plug-in that can parse file_spec.
virtual bool SetLoadAddress(Target &target, lldb::addr_t value, bool value_is_offset)
Sets the load address for an entire module, assuming a rigid slide of sections, if possible in the im...
virtual void Dump(Stream *s)=0
Dump a description of this object to a Stream.
Symtab * GetSymtab()
Gets the symbol table for the currently selected architecture (and object for archives).
virtual bool IsStripped()=0
Detect if this object file has been stripped of local symbols.
virtual bool IsExecutable() const =0
Tells whether this object file is capable of being the main executable for a process.
virtual void ClearSymtab()
Frees the symbol table.
virtual FileSpec & GetFileSpec()
Get accessor to the object file specification.
virtual void CreateSections(SectionList &unified_section_list)=0
virtual void SectionFileAddressesChanged()
Notify the ObjectFile that the file addresses in the Sections for this module have been changed.
virtual UUID GetUUID()=0
Gets the UUID for this object file.
virtual bool GetIsDynamicLinkEditor()
Return true if this file is a dynamic link editor (dyld)
static size_t GetModuleSpecifications(const FileSpec &file, lldb::offset_t file_offset, lldb::offset_t file_size, ModuleSpecList &specs, lldb::DataBufferSP data_sp=lldb::DataBufferSP())
std::optional< FileSpec > FindFile(const FileSpec &orig_spec) const
Finds a source file given a file spec using the path remappings.
bool Replace(llvm::StringRef path, llvm::StringRef replacement, bool notify)
void Append(llvm::StringRef path, llvm::StringRef replacement, bool notify)
bool RemapPath(ConstString path, ConstString &new_path) const
llvm::StringRef GetText() const
Access the regular expression text.
virtual bool LoadScriptingModule(const char *filename, const LoadScriptOptions &options, lldb_private::Status &error, StructuredData::ObjectSP *module_sp=nullptr, FileSpec extra_search_dir={})
This is a SearchFilter that restricts the search to a given module.
size_t GetNumSections(uint32_t depth) const
bool DeleteSection(size_t idx)
lldb::SectionSP GetSectionAtIndex(size_t idx) const
"lldb/Core/SourceLocationSpec.h" A source location specifier class.
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
const char * GetData() const
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
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 IndentLess(unsigned amount=2)
Decrement the current indentation level.
void IndentMore(unsigned amount=2)
Increment the current indentation level.
Defines a list of symbol context objects.
bool GetContextAtIndex(size_t idx, SymbolContext &sc) const
Get accessor for a symbol context at index idx.
uint32_t GetSize() const
Get accessor for a symbol context list size.
const_iterator end() const
bool RemoveContextAtIndex(size_t idx)
void Append(const SymbolContext &sc)
Append a new symbol context to the list.
Defines a symbol context baton that can be handed other debug core functions.
lldb::LanguageType GetLanguage() const
Function * function
The Function for a given query.
ConstString GetFunctionName(Mangled::NamePreference preference=Mangled::ePreferDemangled) const
Find a name of the innermost function for the symbol context.
Block * block
The Block for a given query.
lldb::ModuleSP module_sp
The Module for a given query.
CompileUnit * comp_unit
The CompileUnit for a given query.
void Clear(bool clear_target)
Clear the object's state.
bool GetAddressRange(uint32_t scope, uint32_t range_idx, bool use_inline_block_range, AddressRange &range) const
Get the address range contained within a symbol context.
Symbol * symbol
The Symbol for a given query.
Provides public interface for all SymbolFiles.
virtual size_t ParseTypes(CompileUnit &comp_unit)=0
virtual Symtab * GetSymtab()=0
virtual void SetLoadDebugInfoEnabled()
Specify debug info should be loaded.
virtual void PreloadSymbols()
virtual void FindGlobalVariables(ConstString name, const CompilerDeclContext &parent_decl_ctx, uint32_t max_matches, VariableList &variables)
virtual size_t ParseFunctions(CompileUnit &comp_unit)=0
virtual size_t ParseBlocksRecursive(Function &func)=0
virtual lldb::CompUnitSP GetCompileUnitAtIndex(uint32_t idx)=0
virtual size_t ParseVariablesForContext(const SymbolContext &sc)=0
virtual ObjectFile * GetObjectFile()=0
virtual uint32_t ResolveSymbolContext(const Address &so_addr, lldb::SymbolContextItem resolve_scope, SymbolContext &sc)=0
static void DownloadSymbolFileAsync(const UUID &uuid)
Locate the symbol file for the given UUID on a background thread.
static SymbolVendor * FindPlugin(const lldb::ModuleSP &module_sp, Stream *feedback_strm)
bool ValueIsAddress() const
Address & GetAddressRef()
lldb::SymbolType GetType() const
Symbol * SymbolAtIndex(size_t idx)
void ForEachSymbolContainingFileAddress(lldb::addr_t file_addr, std::function< bool(Symbol *)> const &callback)
Symbol * FindSymbolContainingFileAddress(lldb::addr_t file_addr)
ObjectFile * GetObjectFile() const
uint32_t AppendSymbolIndexesMatchingRegExAndType(const RegularExpression ®ex, lldb::SymbolType symbol_type, std::vector< uint32_t > &indexes, Mangled::NamePreference name_preference=Mangled::ePreferDemangled)
lldb::PlatformSP GetPlatform()
A class that contains all state required for type lookups.
This class tracks the state and results of a TypeQuery.
llvm::Expected< lldb::TypeSystemSP > GetTypeSystemForLanguage(lldb::LanguageType language, Module *module, bool can_create)
void ForEach(std::function< bool(lldb::TypeSystemSP)> const &callback)
void ModuleWasUpdated()
Called after an ObjectFile/SymbolFile has been added to a Module to add any new unwind sections that ...
#define LLDB_INVALID_ADDRESS
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.
@ eLoadScriptFromSymFileFalse
@ eLoadScriptFromSymFileWarn
const char * toString(AppleArm64ExceptionClass EC)
std::shared_ptr< lldb_private::Function > FunctionSP
ScriptLanguage
Script interpreter types.
std::shared_ptr< lldb_private::TypeSystem > TypeSystemSP
DescriptionLevel
Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls.
std::shared_ptr< lldb_private::Platform > PlatformSP
LanguageType
Programming language type.
@ eLanguageTypeUnknown
Unknown or invalid language value.
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::Section > SectionSP
std::shared_ptr< lldb_private::Target > TargetSP
std::shared_ptr< lldb_private::Module > ModuleSP
std::shared_ptr< lldb_private::CompileUnit > CompUnitSP
Options used by Module::FindFunctions.
bool include_inlines
Include inlined functions.
bool include_symbols
Include the symbol table.