LLDB mainline
DWARFIndex.h
Go to the documentation of this file.
1//===-- DWARFIndex.h -------------------------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLDB_SOURCE_PLUGINS_SYMBOLFILE_DWARF_DWARFINDEX_H
10#define LLDB_SOURCE_PLUGINS_SYMBOLFILE_DWARF_DWARFINDEX_H
11
15#include "llvm/DebugInfo/DWARF/DWARFAcceleratorTable.h"
16
17#include "lldb/Core/Module.h"
20
21namespace lldb_private::plugin {
22namespace dwarf {
24class DWARFDIE;
25
27public:
28 DWARFIndex(Module &module) : m_module(module) {}
29 virtual ~DWARFIndex();
30
31 virtual void Preload() = 0;
32
33 /// Finds global variables with the given base name. Any additional filtering
34 /// (e.g., to only retrieve variables from a given context) should be done by
35 /// the consumer.
36 virtual void GetGlobalVariables(
37 ConstString basename,
38 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
39
40 virtual void GetGlobalVariables(
41 const RegularExpression &regex,
42 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
43 /// \a cu must be the skeleton unit if possible, not GetNonSkeletonUnit().
44 virtual void GetGlobalVariables(
45 DWARFUnit &cu,
46 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
47 virtual void GetObjCMethods(
48 ConstString class_name,
49 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
51 ConstString class_name, bool must_be_implementation,
52 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
53 virtual void
55 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
56 virtual void
57 GetTypes(const DWARFDeclContext &context,
58 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
59
60 /// Finds all DIEs whose fully qualified name matches `context`. A base
61 /// implementation is provided, and it uses the entire CU to check the DIE
62 /// parent hierarchy. Specializations should override this if they are able
63 /// to provide a faster implementation.
64 virtual void GetFullyQualifiedType(
65 const DWARFDeclContext &context,
66 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
67 virtual void
69 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
70 /// Get type DIEs meeting requires of \a query.
71 /// in its decl parent chain as subset. A base implementation is provided,
72 /// Specializations should override this if they are able to provide a faster
73 /// implementation.
74 virtual void
76 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
77 /// Get namespace DIEs whose base name match \param name with \param
78 /// parent_decl_ctx in its decl parent chain. A base implementation
79 /// is provided. Specializations should override this if they are able to
80 /// provide a faster implementation.
81 virtual void GetNamespacesWithParents(
82 ConstString name, const CompilerDeclContext &parent_decl_ctx,
83 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
84 virtual void
86 const CompilerDeclContext &parent_decl_ctx,
87 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
88 virtual void
89 GetFunctions(const std::vector<Module::LookupInfo> &lookup_infos,
91 const CompilerDeclContext &parent_decl_ctx,
92 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
93 virtual void
95 llvm::function_ref<IterationAction(DWARFDIE die)> callback) = 0;
96
97 virtual void Dump(Stream &s) = 0;
98
100
101 void ResetStatistics() { m_index_time.reset(); }
102
103protected:
106
107 /// Helper function implementing common logic for processing function dies. If
108 /// the function given by "die" matches search criteria given by
109 /// "parent_decl_ctx" and "name_type_mask", it calls the callback with the
110 /// given die.
112 const Module::LookupInfo &lookup_info, DWARFDIE die,
113 const CompilerDeclContext &parent_decl_ctx,
114 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
115
117 public:
119 const DWARFIndex &index,
120 llvm::function_ref<IterationAction(DWARFDIE die)> callback,
121 llvm::StringRef name);
124 operator()(const llvm::AppleAcceleratorTable::Entry &entry) const;
125
126 private:
129 const llvm::function_ref<IterationAction(DWARFDIE die)> m_callback;
130 const llvm::StringRef m_name;
131 };
133 DIERefCallback(llvm::function_ref<IterationAction(DWARFDIE die)> callback,
134 llvm::StringRef name = {}) const {
135 return DIERefCallbackImpl(*this, callback, name);
136 }
137
138 void ReportInvalidDIERef(DIERef ref, llvm::StringRef name) const;
139
140 /// Implementation of `GetFullyQualifiedType` to check a single entry,
141 /// shareable with derived classes.
143 const DWARFDeclContext &context, DWARFDIE die,
144 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
145
146 /// Check if the type \a die can meet the requirements of \a query.
148 TypeQuery &query, DWARFDIE die,
149 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
151 const CompilerDeclContext &parent_decl_ctx, DWARFDIE die,
152 llvm::function_ref<IterationAction(DWARFDIE die)> callback);
153};
154} // namespace dwarf
155} // namespace lldb_private::plugin
156
157#endif // LLDB_SOURCE_PLUGINS_SYMBOLFILE_DWARF_DWARFINDEX_H
Represents a generic declaration context in a program.
A uniqued constant string class.
Definition ConstString.h:40
A class that encapsulates name lookup information.
Definition Module.h:908
A class that describes an executable image and its associated object and symbol files.
Definition Module.h:90
std::chrono::duration< double > Duration
Definition Statistics.h:37
A stream class that can stream formatted output to a file.
Definition Stream.h:28
A class that contains all state required for type lookups.
Definition Type.h:104
Identifies a DWARF debug info entry within a given Module.
Definition DIERef.h:31
DIERefCallbackImpl(const DWARFIndex &index, llvm::function_ref< IterationAction(DWARFDIE die)> callback, llvm::StringRef name)
const llvm::function_ref< IterationAction(DWARFDIE die)> m_callback
Definition DWARFIndex.h:129
virtual void GetFunctions(const RegularExpression &regex, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
IterationAction GetFullyQualifiedTypeImpl(const DWARFDeclContext &context, DWARFDIE die, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Implementation of GetFullyQualifiedType to check a single entry, shareable with derived classes.
virtual void GetFullyQualifiedType(const DWARFDeclContext &context, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Finds all DIEs whose fully qualified name matches context.
virtual void GetTypesWithQuery(TypeQuery &query, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Get type DIEs meeting requires of query.
StatsDuration::Duration GetIndexTime()
Definition DWARFIndex.h:99
virtual void GetCompleteObjCClass(ConstString class_name, bool must_be_implementation, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
virtual void GetNamespaces(ConstString name, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
virtual void GetGlobalVariables(ConstString basename, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
Finds global variables with the given base name.
virtual void GetObjCMethods(ConstString class_name, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
virtual void GetGlobalVariables(DWARFUnit &cu, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
cu must be the skeleton unit if possible, not GetNonSkeletonUnit().
virtual void Dump(Stream &s)=0
IterationAction ProcessFunctionDIE(const Module::LookupInfo &lookup_info, DWARFDIE die, const CompilerDeclContext &parent_decl_ctx, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Helper function implementing common logic for processing function dies.
DIERefCallbackImpl DIERefCallback(llvm::function_ref< IterationAction(DWARFDIE die)> callback, llvm::StringRef name={}) const
Definition DWARFIndex.h:133
virtual void GetGlobalVariables(const RegularExpression &regex, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
void ReportInvalidDIERef(DIERef ref, llvm::StringRef name) const
virtual void GetTypes(const DWARFDeclContext &context, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
virtual void GetNamespacesWithParents(ConstString name, const CompilerDeclContext &parent_decl_ctx, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Get namespace DIEs whose base name match.
virtual void GetTypes(ConstString name, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
virtual void GetFunctions(const Module::LookupInfo &lookup_info, SymbolFileDWARF &dwarf, const CompilerDeclContext &parent_decl_ctx, llvm::function_ref< IterationAction(DWARFDIE die)> callback)=0
IterationAction ProcessTypeDIEMatchQuery(TypeQuery &query, DWARFDIE die, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
Check if the type die can meet the requirements of query.
IterationAction ProcessNamespaceDieMatchParents(const CompilerDeclContext &parent_decl_ctx, DWARFDIE die, llvm::function_ref< IterationAction(DWARFDIE die)> callback)
IterationAction
Useful for callbacks whose return type indicates whether to continue iteration or short-circuit.