clang 23.0.0git
Mangle.h
Go to the documentation of this file.
1//===--- Mangle.h - Mangle C++ Names ----------------------------*- 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// Defines the C++ name mangling interface.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_AST_MANGLE_H
14#define LLVM_CLANG_AST_MANGLE_H
15
16#include "clang/AST/Decl.h"
18#include "clang/AST/Type.h"
19#include "clang/Basic/ABI.h"
20#include "llvm/ADT/DenseMap.h"
21#include "llvm/Support/Casting.h"
22#include <optional>
23
24namespace llvm {
25class raw_ostream;
26}
27
28namespace clang {
29class ASTContext;
30class BlockDecl;
33class CXXMethodDecl;
34class FunctionDecl;
36class NamedDecl;
37class ObjCMethodDecl;
38class StringLiteral;
39struct ThisAdjustment;
40struct ThunkInfo;
41class VarDecl;
42
43/// Extract mangling function name from MangleContext such that swift can call
44/// it to prepare for ObjCDirect in swift.
45/// Produces the mangling:
46/// \01-[ClassName(Category) method:arg1:arg2:]
47/// Or, if useDirectABI is true (for Direct ABI):
48/// -[ClassName(Category) method:arg1:arg2:]D
49void mangleObjCMethodName(raw_ostream &OS, bool includePrefixByte,
50 bool isInstanceMethod, StringRef ClassName,
51 std::optional<StringRef> CategoryName,
52 StringRef MethodName, bool useDirectABI);
53
54/// MangleContext - Context for tracking state which persists across multiple
55/// calls to the C++ name mangler.
57public:
59
60private:
61 virtual void anchor();
62
63 ASTContext &Context;
64 DiagnosticsEngine &Diags;
65 const ManglerKind Kind;
66 /// For aux target. If true, uses mangling number for aux target from
67 /// ASTContext.
68 bool IsAux = false;
69
70 llvm::DenseMap<const BlockDecl *, unsigned> GlobalBlockIds;
71 llvm::DenseMap<const BlockDecl *, unsigned> LocalBlockIds;
72 llvm::DenseMap<const NamedDecl *, uint64_t> AnonStructIds;
73 llvm::DenseMap<const FunctionDecl *, unsigned> FuncAnonStructSize;
74
75public:
76 ManglerKind getKind() const { return Kind; }
77
78 bool isAux() const { return IsAux; }
79
80 explicit MangleContext(ASTContext &Context, DiagnosticsEngine &Diags,
81 ManglerKind Kind, bool IsAux = false)
82 : Context(Context), Diags(Diags), Kind(Kind), IsAux(IsAux) {}
83
84 virtual ~MangleContext() {}
85
86 ASTContext &getASTContext() const { return Context; }
87
88 DiagnosticsEngine &getDiags() const { return Diags; }
89
90 virtual void startNewFunction() { LocalBlockIds.clear(); }
91
92 unsigned getBlockId(const BlockDecl *BD, bool Local) {
93 llvm::DenseMap<const BlockDecl *, unsigned> &BlockIds =
94 Local ? LocalBlockIds : GlobalBlockIds;
95 std::pair<llvm::DenseMap<const BlockDecl *, unsigned>::iterator, bool>
96 Result = BlockIds.insert(std::make_pair(BD, BlockIds.size()));
97 return Result.first->second;
98 }
99
101 const FunctionDecl *FD = nullptr) {
102 auto FindResult = AnonStructIds.find(D);
103 if (FindResult != AnonStructIds.end())
104 return FindResult->second;
105
106 // If FunctionDecl is passed in, the anonymous structID will be per-function
107 // based.
108 unsigned Id = FD ? FuncAnonStructSize[FD]++ : AnonStructIds.size();
109 std::pair<llvm::DenseMap<const NamedDecl *, uint64_t>::iterator, bool>
110 Result = AnonStructIds.insert(std::make_pair(D, Id));
111 return Result.first->second;
112 }
113
115 llvm::DenseMap<const NamedDecl *, uint64_t>::iterator Result =
116 AnonStructIds.find(D);
117 // The decl should already be inserted, but return 0 in case it is not.
118 if (Result == AnonStructIds.end())
119 return 0;
120 return Result->second;
121 }
122
123 virtual std::string getLambdaString(const CXXRecordDecl *Lambda) = 0;
124
125 /// @name Mangler Entry Points
126 /// @{
127
128 bool shouldMangleDeclName(const NamedDecl *D);
129 virtual bool shouldMangleCXXName(const NamedDecl *D) = 0;
130 virtual bool shouldMangleStringLiteral(const StringLiteral *SL) = 0;
131
132 virtual bool isUniqueInternalLinkageDecl(const NamedDecl *ND) {
133 return false;
134 }
135
137
138 // FIXME: consider replacing raw_ostream & with something like SmallString &.
139 void mangleName(GlobalDecl GD, raw_ostream &);
140 virtual void mangleCXXName(GlobalDecl GD, raw_ostream &) = 0;
141 virtual void mangleThunk(const CXXMethodDecl *MD, const ThunkInfo &Thunk,
142 bool ElideOverrideInfo, raw_ostream &) = 0;
144 const ThunkInfo &Thunk,
145 bool ElideOverrideInfo, raw_ostream &) = 0;
146 virtual void mangleReferenceTemporary(const VarDecl *D,
147 unsigned ManglingNumber,
148 raw_ostream &) = 0;
149 virtual void mangleCXXVTable(const CXXRecordDecl *RD, raw_ostream &) = 0;
150 virtual void mangleCXXRTTI(QualType T, raw_ostream &) = 0;
151 virtual void mangleCXXRTTIName(QualType T, raw_ostream &,
152 bool NormalizeIntegers = false) = 0;
153 virtual void mangleStringLiteral(const StringLiteral *SL, raw_ostream &) = 0;
154 virtual void mangleMSGuidDecl(const MSGuidDecl *GD, raw_ostream &) const;
155
156 void mangleGlobalBlock(const BlockDecl *BD, const NamedDecl *ID,
157 raw_ostream &Out);
159 const BlockDecl *BD, raw_ostream &Out);
161 const BlockDecl *BD, raw_ostream &Out);
162 void mangleBlock(const DeclContext *DC, const BlockDecl *BD,
163 raw_ostream &Out);
164
165 void mangleObjCMethodName(const ObjCMethodDecl *MD, raw_ostream &OS,
166 bool includePrefixByte = true,
167 bool includeCategoryNamespace = true,
168 bool useDirectABI = false) const;
170 raw_ostream &) const;
171
172 virtual void mangleStaticGuardVariable(const VarDecl *D, raw_ostream &) = 0;
173
174 virtual void mangleDynamicInitializer(const VarDecl *D, raw_ostream &) = 0;
175
177 raw_ostream &) = 0;
178
179 virtual void mangleSEHFilterExpression(GlobalDecl EnclosingDecl,
180 raw_ostream &Out) = 0;
181
182 virtual void mangleSEHFinallyBlock(GlobalDecl EnclosingDecl,
183 raw_ostream &Out) = 0;
184
185 /// Generates a unique string for an externally visible type for use with TBAA
186 /// or type uniquing.
187 /// TODO: Extend this to internal types by generating names that are unique
188 /// across translation units so it can be used with LTO.
189 virtual void mangleCanonicalTypeName(QualType T, raw_ostream &,
190 bool NormalizeIntegers = false) = 0;
191
192 /// @}
193};
194
196public:
198 const NamedDecl *);
200 bool IsAux = false)
201 : MangleContext(C, D, MK_Itanium, IsAux) {}
202
203 virtual void mangleCXXVTT(const CXXRecordDecl *RD, raw_ostream &) = 0;
204 virtual void mangleCXXCtorVTable(const CXXRecordDecl *RD, int64_t Offset,
205 const CXXRecordDecl *Type,
206 raw_ostream &) = 0;
208 raw_ostream &) = 0;
210 raw_ostream &) = 0;
211
213 raw_ostream &) = 0;
215 raw_ostream &) = 0;
216
217 virtual void mangleLambdaSig(const CXXRecordDecl *Lambda, raw_ostream &) = 0;
218
219 virtual void mangleDynamicStermFinalizer(const VarDecl *D, raw_ostream &) = 0;
220
221 virtual void mangleModuleInitializer(const Module *Module, raw_ostream &) = 0;
222
223 // This has to live here, otherwise the CXXNameMangler won't have access to
224 // it.
226 static bool classof(const MangleContext *C) {
227 return C->getKind() == MK_Itanium;
228 }
229
230 static ItaniumMangleContext *
231 create(ASTContext &Context, DiagnosticsEngine &Diags, bool IsAux = false);
232 static ItaniumMangleContext *create(ASTContext &Context,
233 DiagnosticsEngine &Diags,
234 DiscriminatorOverrideTy Discriminator,
235 bool IsAux = false);
236};
237
239public:
241 bool IsAux = false)
242 : MangleContext(C, D, MK_Microsoft, IsAux) {}
243
244 /// Mangle vftable symbols. Only a subset of the bases along the path
245 /// to the vftable are included in the name. It's up to the caller to pick
246 /// them correctly.
247 virtual void mangleCXXVFTable(const CXXRecordDecl *Derived,
249 raw_ostream &Out) = 0;
250
251 /// Mangle vbtable symbols. Only a subset of the bases along the path
252 /// to the vbtable are included in the name. It's up to the caller to pick
253 /// them correctly.
254 virtual void mangleCXXVBTable(const CXXRecordDecl *Derived,
256 raw_ostream &Out) = 0;
257
259 unsigned GuardNum,
260 raw_ostream &Out) = 0;
261
263 const MethodVFTableLocation &ML,
264 raw_ostream &Out) = 0;
265
267 const CXXRecordDecl *DstRD,
268 raw_ostream &Out) = 0;
269
270 virtual void mangleCXXThrowInfo(QualType T, bool IsConst, bool IsVolatile,
271 bool IsUnaligned, uint32_t NumEntries,
272 raw_ostream &Out) = 0;
273
274 virtual void mangleCXXCatchableTypeArray(QualType T, uint32_t NumEntries,
275 raw_ostream &Out) = 0;
276
278 CXXCtorType CT, uint32_t Size,
279 uint32_t NVOffset, int32_t VBPtrOffset,
280 uint32_t VBIndex, raw_ostream &Out) = 0;
281
283 const CXXRecordDecl *Derived, uint32_t NVOffset, int32_t VBPtrOffset,
284 uint32_t VBTableOffset, uint32_t Flags, raw_ostream &Out) = 0;
285
286 virtual void mangleCXXRTTIBaseClassArray(const CXXRecordDecl *Derived,
287 raw_ostream &Out) = 0;
288 virtual void
290 raw_ostream &Out) = 0;
291
292 virtual void
295 raw_ostream &Out) = 0;
296
297 static bool classof(const MangleContext *C) {
298 return C->getKind() == MK_Microsoft;
299 }
300
302 create(ASTContext &Context, DiagnosticsEngine &Diags, bool IsAux = false);
303};
304
306public:
307 explicit ASTNameGenerator(ASTContext &Ctx);
309
310 /// Writes name for \p D to \p OS.
311 /// \returns true on failure, false on success.
312 bool writeName(const Decl *D, raw_ostream &OS);
313
314 /// \returns name for \p D
315 std::string getName(const Decl *D);
316
317 /// \returns all applicable mangled names.
318 /// For example C++ constructors/destructors can have multiple.
319 std::vector<std::string> getAllManglings(const Decl *D);
320
321private:
322 class Implementation;
323 std::unique_ptr<Implementation> Impl;
324};
325
326/// Constants used by LLDB for mangling.
328 static constexpr llvm::StringLiteral FunctionLabelPrefix = "$__lldb_func:";
329};
330} // namespace clang
331
332#endif
Enums/classes describing ABI related information about constructors, destructors and thunks.
C Language Family Type Representation.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
Definition ASTContext.h:226
std::string getName(const Decl *D)
Definition Mangle.cpp:674
ASTNameGenerator(ASTContext &Ctx)
Definition Mangle.cpp:665
bool writeName(const Decl *D, raw_ostream &OS)
Writes name for D to OS.
Definition Mangle.cpp:670
std::vector< std::string > getAllManglings(const Decl *D)
Definition Mangle.cpp:678
Represents a block literal declaration, which is like an unnamed FunctionDecl.
Definition Decl.h:4689
Represents a C++ constructor within a class.
Definition DeclCXX.h:2624
Represents a C++ destructor within a class.
Definition DeclCXX.h:2889
Represents a static or instance method of a struct/union/class.
Definition DeclCXX.h:2136
Represents a C++ struct/union/class.
Definition DeclCXX.h:258
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
Definition DeclBase.h:1462
Decl - This represents one declaration (or definition), e.g.
Definition DeclBase.h:86
Concrete class used by the front-end to report problems and issues.
Definition Diagnostic.h:233
Represents a function declaration or definition.
Definition Decl.h:2015
GlobalDecl - represents a global declaration.
Definition GlobalDecl.h:57
virtual DiscriminatorOverrideTy getDiscriminatorOverride() const =0
virtual void mangleDynamicStermFinalizer(const VarDecl *D, raw_ostream &)=0
virtual void mangleCXXVTT(const CXXRecordDecl *RD, raw_ostream &)=0
ItaniumMangleContext(ASTContext &C, DiagnosticsEngine &D, bool IsAux=false)
Definition Mangle.h:199
virtual void mangleItaniumThreadLocalInit(const VarDecl *D, raw_ostream &)=0
virtual void mangleCXXCtorComdat(const CXXConstructorDecl *D, raw_ostream &)=0
virtual void mangleLambdaSig(const CXXRecordDecl *Lambda, raw_ostream &)=0
virtual void mangleCXXDtorComdat(const CXXDestructorDecl *D, raw_ostream &)=0
virtual void mangleItaniumThreadLocalWrapper(const VarDecl *D, raw_ostream &)=0
static ItaniumMangleContext * create(ASTContext &Context, DiagnosticsEngine &Diags, bool IsAux=false)
virtual void mangleCXXCtorVTable(const CXXRecordDecl *RD, int64_t Offset, const CXXRecordDecl *Type, raw_ostream &)=0
virtual void mangleModuleInitializer(const Module *Module, raw_ostream &)=0
static bool classof(const MangleContext *C)
Definition Mangle.h:226
UnsignedOrNone(*)(ASTContext &, const NamedDecl *) DiscriminatorOverrideTy
Definition Mangle.h:197
A global _GUID constant.
Definition DeclCXX.h:4414
void mangleBlock(const DeclContext *DC, const BlockDecl *BD, raw_ostream &Out)
Definition Mangle.cpp:349
virtual void mangleCXXDtorThunk(const CXXDestructorDecl *DD, CXXDtorType Type, const ThunkInfo &Thunk, bool ElideOverrideInfo, raw_ostream &)=0
virtual void mangleCXXRTTI(QualType T, raw_ostream &)=0
bool isAux() const
Definition Mangle.h:78
unsigned getBlockId(const BlockDecl *BD, bool Local)
Definition Mangle.h:92
virtual std::string getLambdaString(const CXXRecordDecl *Lambda)=0
virtual bool shouldMangleStringLiteral(const StringLiteral *SL)=0
void mangleCtorBlock(const CXXConstructorDecl *CD, CXXCtorType CT, const BlockDecl *BD, raw_ostream &Out)
Definition Mangle.cpp:331
ASTContext & getASTContext() const
Definition Mangle.h:86
uint64_t getAnonymousStructIdForDebugInfo(const NamedDecl *D)
Definition Mangle.h:114
virtual void mangleDynamicAtExitDestructor(const VarDecl *D, raw_ostream &)=0
void mangleGlobalBlock(const BlockDecl *BD, const NamedDecl *ID, raw_ostream &Out)
Definition Mangle.cpp:314
void mangleObjCMethodName(const ObjCMethodDecl *MD, raw_ostream &OS, bool includePrefixByte=true, bool includeCategoryNamespace=true, bool useDirectABI=false) const
Definition Mangle.cpp:384
virtual bool isUniqueInternalLinkageDecl(const NamedDecl *ND)
Definition Mangle.h:132
uint64_t getAnonymousStructId(const NamedDecl *D, const FunctionDecl *FD=nullptr)
Definition Mangle.h:100
bool shouldMangleDeclName(const NamedDecl *D)
Definition Mangle.cpp:127
virtual void mangleSEHFilterExpression(GlobalDecl EnclosingDecl, raw_ostream &Out)=0
virtual void mangleMSGuidDecl(const MSGuidDecl *GD, raw_ostream &) const
Definition Mangle.cpp:299
virtual void mangleThunk(const CXXMethodDecl *MD, const ThunkInfo &Thunk, bool ElideOverrideInfo, raw_ostream &)=0
void mangleName(GlobalDecl GD, raw_ostream &)
Definition Mangle.cpp:190
virtual ~MangleContext()
Definition Mangle.h:84
virtual void mangleCanonicalTypeName(QualType T, raw_ostream &, bool NormalizeIntegers=false)=0
Generates a unique string for an externally visible type for use with TBAA or type uniquing.
virtual void mangleStringLiteral(const StringLiteral *SL, raw_ostream &)=0
virtual void mangleCXXName(GlobalDecl GD, raw_ostream &)=0
ManglerKind getKind() const
Definition Mangle.h:76
virtual void needsUniqueInternalLinkageNames()
Definition Mangle.h:136
virtual void mangleReferenceTemporary(const VarDecl *D, unsigned ManglingNumber, raw_ostream &)=0
virtual void startNewFunction()
Definition Mangle.h:90
DiagnosticsEngine & getDiags() const
Definition Mangle.h:88
virtual bool shouldMangleCXXName(const NamedDecl *D)=0
virtual void mangleCXXRTTIName(QualType T, raw_ostream &, bool NormalizeIntegers=false)=0
virtual void mangleDynamicInitializer(const VarDecl *D, raw_ostream &)=0
void mangleDtorBlock(const CXXDestructorDecl *CD, CXXDtorType DT, const BlockDecl *BD, raw_ostream &Out)
Definition Mangle.cpp:340
virtual void mangleCXXVTable(const CXXRecordDecl *RD, raw_ostream &)=0
MangleContext(ASTContext &Context, DiagnosticsEngine &Diags, ManglerKind Kind, bool IsAux=false)
Definition Mangle.h:80
virtual void mangleSEHFinallyBlock(GlobalDecl EnclosingDecl, raw_ostream &Out)=0
void mangleObjCMethodNameAsSourceName(const ObjCMethodDecl *MD, raw_ostream &) const
Definition Mangle.cpp:452
virtual void mangleStaticGuardVariable(const VarDecl *D, raw_ostream &)=0
virtual void mangleCXXVFTable(const CXXRecordDecl *Derived, ArrayRef< const CXXRecordDecl * > BasePath, raw_ostream &Out)=0
Mangle vftable symbols.
virtual void mangleVirtualMemPtrThunk(const CXXMethodDecl *MD, const MethodVFTableLocation &ML, raw_ostream &Out)=0
virtual void mangleCXXRTTICompleteObjectLocator(const CXXRecordDecl *Derived, ArrayRef< const CXXRecordDecl * > BasePath, raw_ostream &Out)=0
virtual void mangleCXXThrowInfo(QualType T, bool IsConst, bool IsVolatile, bool IsUnaligned, uint32_t NumEntries, raw_ostream &Out)=0
static bool classof(const MangleContext *C)
Definition Mangle.h:297
virtual void mangleCXXVBTable(const CXXRecordDecl *Derived, ArrayRef< const CXXRecordDecl * > BasePath, raw_ostream &Out)=0
Mangle vbtable symbols.
virtual void mangleCXXRTTIClassHierarchyDescriptor(const CXXRecordDecl *Derived, raw_ostream &Out)=0
virtual void mangleThreadSafeStaticGuardVariable(const VarDecl *VD, unsigned GuardNum, raw_ostream &Out)=0
static MicrosoftMangleContext * create(ASTContext &Context, DiagnosticsEngine &Diags, bool IsAux=false)
virtual void mangleCXXCatchableTypeArray(QualType T, uint32_t NumEntries, raw_ostream &Out)=0
virtual void mangleCXXRTTIBaseClassDescriptor(const CXXRecordDecl *Derived, uint32_t NVOffset, int32_t VBPtrOffset, uint32_t VBTableOffset, uint32_t Flags, raw_ostream &Out)=0
virtual void mangleCXXCatchableType(QualType T, const CXXConstructorDecl *CD, CXXCtorType CT, uint32_t Size, uint32_t NVOffset, int32_t VBPtrOffset, uint32_t VBIndex, raw_ostream &Out)=0
virtual void mangleCXXRTTIBaseClassArray(const CXXRecordDecl *Derived, raw_ostream &Out)=0
virtual void mangleCXXVirtualDisplacementMap(const CXXRecordDecl *SrcRD, const CXXRecordDecl *DstRD, raw_ostream &Out)=0
MicrosoftMangleContext(ASTContext &C, DiagnosticsEngine &D, bool IsAux=false)
Definition Mangle.h:240
Describes a module or submodule.
Definition Module.h:246
This represents a decl that may have a name.
Definition Decl.h:274
ObjCMethodDecl - Represents an instance or class method declaration.
Definition DeclObjC.h:140
A (possibly-)qualified type.
Definition TypeBase.h:937
StringLiteral - This represents a string literal expression, e.g.
Definition Expr.h:1802
The base class of the type hierarchy.
Definition TypeBase.h:1866
Represents a variable declaration or definition.
Definition Decl.h:926
The JSON file list parser is used to communicate input to InstallAPI.
CXXCtorType
C++ constructor types.
Definition ABI.h:24
bool isInstanceMethod(const Decl *D)
Definition Attr.h:120
void mangleObjCMethodName(raw_ostream &OS, bool includePrefixByte, bool isInstanceMethod, StringRef ClassName, std::optional< StringRef > CategoryName, StringRef MethodName, bool useDirectABI)
Extract mangling function name from MangleContext such that swift can call it to prepare for ObjCDire...
Definition Mangle.cpp:32
@ Result
The result type of a method or function.
Definition TypeBase.h:905
OptionalUnsigned< unsigned > UnsignedOrNone
CXXDtorType
C++ destructor types.
Definition ABI.h:34
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
Constants used by LLDB for mangling.
Definition Mangle.h:327
static constexpr llvm::StringLiteral FunctionLabelPrefix
Definition Mangle.h:328
A this pointer adjustment.
Definition Thunk.h:92
The this pointer adjustment as well as an optional return adjustment for a thunk.
Definition Thunk.h:157