35#include "llvm/ADT/StringExtras.h"
36#include "llvm/Support/ErrorHandling.h"
37#include "llvm/Support/raw_ostream.h"
38#include "llvm/TargetParser/RISCVTargetParser.h"
42namespace UnsupportedItaniumManglingKind =
43 clang::diag::UnsupportedItaniumManglingKind;
47static bool isLocalContainerContext(
const DeclContext *DC) {
51static const FunctionDecl *getStructor(
const FunctionDecl *fn) {
53 return ftd->getTemplatedDecl();
58static const NamedDecl *getStructor(
const NamedDecl *
decl) {
59 const FunctionDecl *fn = dyn_cast_or_null<FunctionDecl>(
decl);
60 return (fn ? getStructor(fn) :
decl);
63static bool isLambda(
const NamedDecl *ND) {
64 const CXXRecordDecl *
Record = dyn_cast<CXXRecordDecl>(ND);
71static const unsigned UnknownArity = ~0U;
73class ItaniumMangleContextImpl :
public ItaniumMangleContext {
74 using DiscriminatorKeyTy = std::pair<const DeclContext *, IdentifierInfo *>;
75 llvm::DenseMap<DiscriminatorKeyTy, unsigned> Discriminator;
76 llvm::DenseMap<const NamedDecl*, unsigned> Uniquifier;
77 const DiscriminatorOverrideTy DiscriminatorOverride =
nullptr;
78 NamespaceDecl *StdNamespace =
nullptr;
80 bool NeedsUniqueInternalLinkageNames =
false;
83 explicit ItaniumMangleContextImpl(
84 ASTContext &Context, DiagnosticsEngine &Diags,
85 DiscriminatorOverrideTy DiscriminatorOverride,
bool IsAux =
false)
86 : ItaniumMangleContext(Context, Diags, IsAux),
87 DiscriminatorOverride(DiscriminatorOverride) {}
92 bool shouldMangleCXXName(
const NamedDecl *D)
override;
93 bool shouldMangleStringLiteral(
const StringLiteral *)
override {
98 void needsUniqueInternalLinkageNames()
override {
99 NeedsUniqueInternalLinkageNames =
true;
102 void mangleCXXName(GlobalDecl GD, raw_ostream &)
override;
103 void mangleThunk(
const CXXMethodDecl *MD,
const ThunkInfo &Thunk,
bool,
104 raw_ostream &)
override;
106 const ThunkInfo &Thunk,
bool, raw_ostream &)
override;
107 void mangleReferenceTemporary(
const VarDecl *D,
unsigned ManglingNumber,
108 raw_ostream &)
override;
109 void mangleCXXVTable(
const CXXRecordDecl *RD, raw_ostream &)
override;
110 void mangleCXXVTT(
const CXXRecordDecl *RD, raw_ostream &)
override;
111 void mangleCXXCtorVTable(
const CXXRecordDecl *RD, int64_t Offset,
112 const CXXRecordDecl *
Type, raw_ostream &)
override;
113 void mangleCXXRTTI(QualType T, raw_ostream &)
override;
114 void mangleCXXRTTIName(QualType T, raw_ostream &,
115 bool NormalizeIntegers)
override;
116 void mangleCanonicalTypeName(QualType T, raw_ostream &,
117 bool NormalizeIntegers)
override;
119 void mangleCXXCtorComdat(
const CXXConstructorDecl *D, raw_ostream &)
override;
120 void mangleCXXDtorComdat(
const CXXDestructorDecl *D, raw_ostream &)
override;
121 void mangleStaticGuardVariable(
const VarDecl *D, raw_ostream &)
override;
122 void mangleDynamicInitializer(
const VarDecl *D, raw_ostream &Out)
override;
123 void mangleDynamicAtExitDestructor(
const VarDecl *D,
124 raw_ostream &Out)
override;
125 void mangleDynamicStermFinalizer(
const VarDecl *D, raw_ostream &Out)
override;
126 void mangleSEHFilterExpression(GlobalDecl EnclosingDecl,
127 raw_ostream &Out)
override;
128 void mangleSEHFinallyBlock(GlobalDecl EnclosingDecl,
129 raw_ostream &Out)
override;
130 void mangleItaniumThreadLocalInit(
const VarDecl *D, raw_ostream &)
override;
131 void mangleItaniumThreadLocalWrapper(
const VarDecl *D,
132 raw_ostream &)
override;
134 void mangleStringLiteral(
const StringLiteral *, raw_ostream &)
override;
136 void mangleLambdaSig(
const CXXRecordDecl *Lambda, raw_ostream &)
override;
138 void mangleModuleInitializer(
const Module *
Module, raw_ostream &)
override;
140 bool getNextDiscriminator(
const NamedDecl *ND,
unsigned &disc) {
146 if (
const auto *Tag = dyn_cast<TagDecl>(ND);
147 Tag &&
Tag->getName().empty() && !
Tag->getTypedefNameForAnonDecl())
152 unsigned discriminator = getASTContext().getManglingNumber(ND, isAux());
153 if (discriminator == 1)
155 disc = discriminator - 2;
160 unsigned &discriminator = Uniquifier[ND];
161 if (!discriminator) {
162 const DeclContext *DC = getEffectiveDeclContext(ND);
163 discriminator = ++Discriminator[std::make_pair(DC, ND->
getIdentifier())];
165 if (discriminator == 1)
167 disc = discriminator-2;
171 std::string getLambdaString(
const CXXRecordDecl *Lambda)
override {
174 assert(Lambda->
isLambda() &&
"RD must be a lambda!");
175 std::string Name(
"<lambda");
179 const ParmVarDecl *Parm = dyn_cast_or_null<ParmVarDecl>(LambdaContextDecl);
180 const FunctionDecl *
Func =
184 unsigned DefaultArgNo =
186 Name += llvm::utostr(DefaultArgNo);
190 if (LambdaManglingNumber)
191 LambdaId = LambdaManglingNumber;
193 LambdaId = getAnonymousStructIdForDebugInfo(Lambda);
195 Name += llvm::utostr(LambdaId);
200 DiscriminatorOverrideTy getDiscriminatorOverride()
const override {
201 return DiscriminatorOverride;
204 NamespaceDecl *getStdNamespace();
206 const DeclContext *getEffectiveDeclContext(
const Decl *D);
207 const DeclContext *getEffectiveParentContext(
const DeclContext *DC) {
208 return getEffectiveDeclContext(
cast<Decl>(DC));
211 bool isInternalLinkageDecl(
const NamedDecl *ND);
217class CXXNameMangler {
218 ItaniumMangleContextImpl &Context;
222 bool NormalizeIntegers =
false;
224 bool NullOut =
false;
229 bool DisableDerivedAbiTags =
false;
234 const NamedDecl *Structor;
235 unsigned StructorType = 0;
240 unsigned TemplateDepthOffset = 0;
245 class FunctionTypeDepthState {
247 unsigned InFunctionDeclSuffix : 1;
250 FunctionTypeDepthState() : Depth(0), InFunctionDeclSuffix(0) {}
252 unsigned getNestingDepth(
unsigned ParmDepth)
const {
255 assert(ParmDepth < Depth &&
256 "ParmVarDecl is not visible in current parameter environment");
257 return Depth - ParmDepth - InFunctionDeclSuffix;
260 FunctionTypeDepthState push() {
261 FunctionTypeDepthState Saved = *
this;
263 InFunctionDeclSuffix = 0;
267 void pop(FunctionTypeDepthState Saved) {
268 assert(Depth == Saved.Depth + 1 &&
"unbalanced function type depth pop");
272 void enterFunctionDeclSuffix() { InFunctionDeclSuffix = 1; }
273 void leaveFunctionDeclSuffix() { InFunctionDeclSuffix = 0; }
280 using AbiTagList = SmallVector<StringRef, 4>;
285 class AbiTagState final {
287 explicit AbiTagState(AbiTagState *&Head) : LinkHead(Head) {
293 AbiTagState(
const AbiTagState &) =
delete;
294 AbiTagState &operator=(
const AbiTagState &) =
delete;
296 ~AbiTagState() { pop(); }
298 void write(raw_ostream &Out,
const NamedDecl *ND,
299 ArrayRef<StringRef> AdditionalAbiTags) {
303 AdditionalAbiTags.empty() &&
304 "only function and variables need a list of additional abi tags");
305 if (
const auto *NS = dyn_cast<NamespaceDecl>(ND)) {
306 if (
const auto *AbiTag = NS->getAttr<AbiTagAttr>())
307 llvm::append_range(UsedAbiTags, AbiTag->tags());
314 if (
const auto *AbiTag = ND->
getAttr<AbiTagAttr>()) {
315 llvm::append_range(UsedAbiTags, AbiTag->tags());
316 llvm::append_range(TagList, AbiTag->tags());
319 llvm::append_range(UsedAbiTags, AdditionalAbiTags);
320 llvm::append_range(TagList, AdditionalAbiTags);
323 TagList.erase(llvm::unique(TagList), TagList.end());
325 writeSortedUniqueAbiTags(Out, TagList);
328 const AbiTagList &getUsedAbiTags()
const {
return UsedAbiTags; }
329 void setUsedAbiTags(
const AbiTagList &AbiTags) {
330 UsedAbiTags = AbiTags;
333 const AbiTagList &getEmittedAbiTags()
const {
334 return EmittedAbiTags;
337 const AbiTagList &getSortedUniqueUsedAbiTags() {
338 llvm::sort(UsedAbiTags);
339 UsedAbiTags.erase(llvm::unique(UsedAbiTags), UsedAbiTags.end());
345 AbiTagList UsedAbiTags;
347 AbiTagList EmittedAbiTags;
349 AbiTagState *&LinkHead;
350 AbiTagState *Parent =
nullptr;
353 assert(LinkHead ==
this &&
354 "abi tag link head must point to us on destruction");
356 Parent->UsedAbiTags.insert(Parent->UsedAbiTags.end(),
357 UsedAbiTags.begin(), UsedAbiTags.end());
358 Parent->EmittedAbiTags.insert(Parent->EmittedAbiTags.end(),
359 EmittedAbiTags.begin(),
360 EmittedAbiTags.end());
365 void writeSortedUniqueAbiTags(raw_ostream &Out,
const AbiTagList &AbiTags) {
366 for (
const auto &Tag : AbiTags) {
367 EmittedAbiTags.push_back(Tag);
375 AbiTagState *AbiTags =
nullptr;
376 AbiTagState AbiTagsRoot;
378 llvm::DenseMap<uintptr_t, unsigned> Substitutions;
379 llvm::DenseMap<StringRef, unsigned> ModuleSubstitutions;
381 ASTContext &getASTContext()
const {
return Context.getASTContext(); }
383 bool isCompatibleWith(LangOptions::ClangABI Ver) {
387 bool isStd(
const NamespaceDecl *NS);
388 bool isStdNamespace(
const DeclContext *DC);
390 const RecordDecl *GetLocalClassDecl(
const Decl *D);
391 bool isSpecializedAs(QualType S, llvm::StringRef Name, QualType A);
392 bool isStdCharSpecialization(
const ClassTemplateSpecializationDecl *SD,
393 llvm::StringRef Name,
bool HasAllocator);
396 CXXNameMangler(ItaniumMangleContextImpl &
C, raw_ostream &Out_,
397 const NamedDecl *D =
nullptr,
bool NullOut_ =
false)
398 : Context(
C),
Out(Out_), NullOut(NullOut_), Structor(getStructor(D)),
399 AbiTagsRoot(AbiTags) {
404 CXXNameMangler(ItaniumMangleContextImpl &
C, raw_ostream &Out_,
406 : Context(
C),
Out(Out_), Structor(getStructor(D)), StructorType(
Type),
407 AbiTagsRoot(AbiTags) {}
408 CXXNameMangler(ItaniumMangleContextImpl &
C, raw_ostream &Out_,
410 : Context(
C),
Out(Out_), Structor(getStructor(D)), StructorType(
Type),
411 AbiTagsRoot(AbiTags) {}
413 CXXNameMangler(ItaniumMangleContextImpl &
C, raw_ostream &Out_,
414 bool NormalizeIntegers_)
415 : Context(
C),
Out(Out_), NormalizeIntegers(NormalizeIntegers_),
416 NullOut(
false), Structor(
nullptr), AbiTagsRoot(AbiTags) {}
417 CXXNameMangler(CXXNameMangler &Outer, raw_ostream &Out_)
418 : Context(Outer.Context),
Out(Out_),
419 NormalizeIntegers(Outer.NormalizeIntegers), Structor(Outer.Structor),
420 StructorType(Outer.StructorType), SeqID(Outer.SeqID),
421 FunctionTypeDepth(Outer.FunctionTypeDepth), AbiTagsRoot(AbiTags),
422 Substitutions(Outer.Substitutions),
423 ModuleSubstitutions(Outer.ModuleSubstitutions) {}
425 CXXNameMangler(CXXNameMangler &Outer, llvm::raw_null_ostream &Out_)
426 : CXXNameMangler(Outer, (raw_ostream &)Out_) {
430 struct WithTemplateDepthOffset {
unsigned Offset; };
431 CXXNameMangler(ItaniumMangleContextImpl &
C, raw_ostream &Out,
432 WithTemplateDepthOffset Offset)
433 : CXXNameMangler(
C,
Out) {
434 TemplateDepthOffset = Offset.Offset;
437 raw_ostream &getStream() {
return Out; }
439 void disableDerivedAbiTags() { DisableDerivedAbiTags =
true; }
440 static bool shouldHaveAbiTags(ItaniumMangleContextImpl &
C,
const VarDecl *VD);
442 void mangle(GlobalDecl GD);
443 void mangleCallOffset(int64_t NonVirtual, int64_t
Virtual);
444 void mangleNumber(
const llvm::APSInt &I);
445 void mangleNumber(int64_t Number);
446 void mangleFloat(
const llvm::APFloat &F);
447 void mangleFunctionEncoding(GlobalDecl GD);
448 void mangleSeqID(
unsigned SeqID);
449 void mangleName(GlobalDecl GD);
450 void mangleType(QualType T);
451 void mangleCXXRecordDecl(
const CXXRecordDecl *
Record,
452 bool SuppressSubstitution =
false);
453 void mangleLambdaSig(
const CXXRecordDecl *Lambda);
454 void mangleModuleNamePrefix(StringRef Name,
bool IsPartition =
false);
455 void mangleVendorQualifier(StringRef Name);
456 void mangleVendorType(StringRef Name);
459 bool mangleSubstitution(
const NamedDecl *ND);
460 bool mangleSubstitution(QualType T);
466 bool mangleStandardSubstitution(
const NamedDecl *ND);
468 void addSubstitution(
const NamedDecl *ND) {
471 addSubstitution(
reinterpret_cast<uintptr_t>(ND));
473 void addSubstitution(QualType T);
477 void extendSubstitutions(CXXNameMangler*
Other);
479 void mangleUnresolvedPrefix(NestedNameSpecifier Qualifier,
480 bool recursive =
false);
481 void mangleUnresolvedName(NestedNameSpecifier Qualifier, DeclarationName name,
482 const TemplateArgumentLoc *TemplateArgs,
483 unsigned NumTemplateArgs,
484 unsigned KnownArity = UnknownArity);
486 void mangleFunctionEncodingBareType(
const FunctionDecl *FD);
488 void mangleNameWithAbiTags(GlobalDecl GD,
489 ArrayRef<StringRef> AdditionalAbiTags = {});
490 void mangleModuleName(
const NamedDecl *ND);
491 void mangleTemplateName(
const TemplateDecl *TD,
492 ArrayRef<TemplateArgument> Args);
493 void mangleUnqualifiedName(GlobalDecl GD,
const DeclContext *DC,
494 ArrayRef<StringRef> AdditionalAbiTags = {}) {
496 UnknownArity, AdditionalAbiTags);
498 void mangleUnqualifiedName(GlobalDecl GD, DeclarationName Name,
499 const DeclContext *DC,
unsigned KnownArity,
500 ArrayRef<StringRef> AdditionalAbiTags);
501 void mangleUnscopedName(GlobalDecl GD,
const DeclContext *DC,
502 ArrayRef<StringRef> AdditionalAbiTags = {});
503 void mangleUnscopedTemplateName(GlobalDecl GD,
const DeclContext *DC,
504 ArrayRef<StringRef> AdditionalAbiTags = {});
505 void mangleSourceName(
const IdentifierInfo *II);
506 void mangleConstructorName(
const CXXConstructorDecl *CCD,
507 ArrayRef<StringRef> AdditionalAbiTags = {});
508 void mangleDestructorName(
const CXXDestructorDecl *CDD,
509 ArrayRef<StringRef> AdditionalAbiTags = {});
510 void mangleRegCallName(
const IdentifierInfo *II);
511 void mangleDeviceStubName(
const IdentifierInfo *II);
512 void mangleOCLDeviceStubName(
const IdentifierInfo *II);
513 void mangleSourceNameWithAbiTags(
const NamedDecl *ND,
514 ArrayRef<StringRef> AdditionalAbiTags = {});
515 void mangleLocalName(GlobalDecl GD,
516 ArrayRef<StringRef> AdditionalAbiTags = {});
517 void mangleBlockForPrefix(
const BlockDecl *
Block);
518 void mangleUnqualifiedBlock(
const BlockDecl *
Block);
519 void mangleTemplateParamDecl(
const NamedDecl *Decl);
520 void mangleTemplateParameterList(
const TemplateParameterList *Params);
521 void mangleTypeConstraint(
const TemplateDecl *
Concept,
522 ArrayRef<TemplateArgument> Arguments);
523 void mangleTypeConstraint(
const TypeConstraint *Constraint);
524 void mangleRequiresClause(
const Expr *RequiresClause);
525 void mangleLambda(
const CXXRecordDecl *Lambda);
526 void mangleNestedName(GlobalDecl GD,
const DeclContext *DC,
527 ArrayRef<StringRef> AdditionalAbiTags = {},
528 bool NoFunction =
false);
529 void mangleNestedName(
const TemplateDecl *TD,
530 ArrayRef<TemplateArgument> Args);
531 void mangleNestedNameWithClosurePrefix(GlobalDecl GD,
532 const NamedDecl *PrefixND,
533 ArrayRef<StringRef> AdditionalAbiTags);
534 void manglePrefix(NestedNameSpecifier Qualifier);
535 void manglePrefix(
const DeclContext *DC,
bool NoFunction=
false);
536 void manglePrefix(QualType
type);
537 void mangleTemplatePrefix(GlobalDecl GD,
bool NoFunction=
false);
539 const NamedDecl *getClosurePrefix(
const Decl *ND);
540 void mangleClosurePrefix(
const NamedDecl *ND,
bool NoFunction =
false);
541 bool mangleUnresolvedTypeOrSimpleId(QualType DestroyedType,
542 StringRef Prefix =
"");
543 void mangleOperatorName(DeclarationName Name,
unsigned Arity);
545 void mangleQualifiers(Qualifiers Quals,
const DependentAddressSpaceType *DAST =
nullptr);
551#define ABSTRACT_TYPE(CLASS, PARENT)
552#define NON_CANONICAL_TYPE(CLASS, PARENT)
553#define TYPE(CLASS, PARENT) void mangleType(const CLASS##Type *T);
554#include "clang/AST/TypeNodes.inc"
556 void mangleType(
const TagType*);
558 static StringRef getCallingConvQualifierName(
CallingConv CC);
561 void mangleSMEAttrs(
unsigned SMEAttrs);
564 void mangleNeonVectorType(
const VectorType *T);
566 void mangleAArch64NeonVectorType(
const VectorType *T);
568 void mangleAArch64FixedSveVectorType(
const VectorType *T);
570 void mangleRISCVFixedRVVVectorType(
const VectorType *T);
573 void mangleIntegerLiteral(
QualType T,
const llvm::APSInt &
Value);
574 void mangleFloatLiteral(
QualType T,
const llvm::APFloat &
V);
575 void mangleFixedPointLiteral();
578 void mangleMemberExprBase(
const Expr *base,
bool isArrow);
579 void mangleMemberExpr(
const Expr *base,
bool isArrow,
583 unsigned NumTemplateArgs,
unsigned knownArity);
584 void mangleCastExpression(
const Expr *E, StringRef CastEncoding);
585 void mangleInitListElements(
const InitListExpr *InitList);
588 void mangleReferenceToPack(
const NamedDecl *ND);
589 void mangleExpression(
const Expr *E,
unsigned Arity = UnknownArity,
590 bool AsTemplateArg =
false);
594 struct TemplateArgManglingInfo;
597 unsigned NumTemplateArgs);
600 void mangleTemplateArg(TemplateArgManglingInfo &Info,
unsigned Index,
603 void mangleTemplateArgExpr(
const Expr *E);
605 bool NeedExactType =
false);
607 void mangleTemplateParameter(
unsigned Depth,
unsigned Index);
615 AbiTagList makeFunctionReturnTypeTags(
const FunctionDecl *FD);
617 AbiTagList makeVariableTypeTags(
const VarDecl *VD);
625 getASTContext(), getASTContext().getTranslationUnitDecl(),
626 false, SourceLocation(), SourceLocation(),
627 &getASTContext().Idents.get(
"std"),
650ItaniumMangleContextImpl::getEffectiveDeclContext(
const Decl *D) {
657 if (
const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(D)) {
659 if (ParmVarDecl *ContextParam =
660 dyn_cast_or_null<ParmVarDecl>(RD->getLambdaContextDecl()))
661 return ContextParam->getDeclContext();
665 if (
const BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
666 if (ParmVarDecl *ContextParam =
667 dyn_cast_or_null<ParmVarDecl>(BD->getBlockManglingContextDecl()))
668 return ContextParam->getDeclContext();
676 if (D == getASTContext().getVaListTagDecl()) {
677 const llvm::Triple &T = getASTContext().getTargetInfo().getTriple();
678 if (T.isARM() || T.isThumb() || T.isAArch64())
679 return getStdNamespace();
685 return getEffectiveDeclContext(
cast<Decl>(DC));
688 if (
const auto *VD = dyn_cast<VarDecl>(D)) {
690 const DeclContext *ParentDC = getEffectiveParentContext(Lambda);
694 if (isLocalContainerContext(ParentDC))
698 return getASTContext().getTranslationUnitDecl();
701 if (
const auto *FD = !getASTContext().getLangOpts().isCompatibleWith(
702 LangOptions::ClangABI::Ver19)
704 : dyn_cast<FunctionDecl>(D)) {
706 return getASTContext().getTranslationUnitDecl();
709 if (FD->isMemberLikeConstrainedFriend() &&
710 !getASTContext().getLangOpts().isCompatibleWith(
711 LangOptions::ClangABI::Ver17))
718bool ItaniumMangleContextImpl::isInternalLinkageDecl(
const NamedDecl *ND) {
721 getEffectiveDeclContext(ND)->isFileContext() &&
728bool ItaniumMangleContextImpl::isUniqueInternalLinkageDecl(
729 const NamedDecl *ND) {
730 if (!NeedsUniqueInternalLinkageNames || !ND)
733 const auto *FD = dyn_cast<FunctionDecl>(ND);
739 if (!FD->getType()->getAs<FunctionProtoType>())
742 if (isInternalLinkageDecl(ND))
748bool ItaniumMangleContextImpl::shouldMangleCXXName(
const NamedDecl *D) {
749 if (
const auto *FD = dyn_cast<FunctionDecl>(D)) {
752 if (FD->hasAttr<OverloadableAttr>())
768 if (FD->isMSVCRTEntryPoint())
782 if (!getASTContext().getLangOpts().
CPlusPlus)
785 if (
const auto *VD = dyn_cast<VarDecl>(D)) {
796 const DeclContext *DC = getEffectiveDeclContext(D);
798 !CXXNameMangler::shouldHaveAbiTags(*
this, VD) &&
800 !VD->getOwningModuleForLinkage())
807void CXXNameMangler::writeAbiTags(
const NamedDecl *ND,
808 ArrayRef<StringRef> AdditionalAbiTags) {
809 assert(AbiTags &&
"require AbiTagState");
810 AbiTags->write(Out, ND,
811 DisableDerivedAbiTags ? ArrayRef<StringRef>{}
812 : AdditionalAbiTags);
815void CXXNameMangler::mangleSourceNameWithAbiTags(
816 const NamedDecl *ND, ArrayRef<StringRef> AdditionalAbiTags) {
818 writeAbiTags(ND, AdditionalAbiTags);
821void CXXNameMangler::mangle(GlobalDecl GD) {
827 mangleFunctionEncoding(GD);
828 else if (
isa<VarDecl, FieldDecl, MSGuidDecl, TemplateParamObjectDecl,
831 else if (
const IndirectFieldDecl *IFD =
832 dyn_cast<IndirectFieldDecl>(GD.
getDecl()))
833 mangleName(IFD->getAnonField());
835 llvm_unreachable(
"unexpected kind of global decl");
838void CXXNameMangler::mangleFunctionEncoding(GlobalDecl GD) {
843 if (!Context.shouldMangleDeclName(FD)) {
848 AbiTagList ReturnTypeAbiTags = makeFunctionReturnTypeTags(FD);
849 if (ReturnTypeAbiTags.empty()) {
858 FunctionTypeDepthState Saved = FunctionTypeDepth.push();
860 FunctionTypeDepth.pop(Saved);
861 mangleFunctionEncodingBareType(FD);
868 SmallString<256> FunctionEncodingBuf;
869 llvm::raw_svector_ostream FunctionEncodingStream(FunctionEncodingBuf);
870 CXXNameMangler FunctionEncodingMangler(*
this, FunctionEncodingStream);
872 FunctionEncodingMangler.disableDerivedAbiTags();
874 FunctionTypeDepthState Saved = FunctionTypeDepth.push();
875 FunctionEncodingMangler.mangleNameWithAbiTags(FD);
876 FunctionTypeDepth.pop(Saved);
879 size_t EncodingPositionStart = FunctionEncodingStream.str().size();
880 FunctionEncodingMangler.mangleFunctionEncodingBareType(FD);
884 const AbiTagList &UsedAbiTags =
885 FunctionEncodingMangler.AbiTagsRoot.getSortedUniqueUsedAbiTags();
886 AbiTagList AdditionalAbiTags(ReturnTypeAbiTags.size());
887 AdditionalAbiTags.erase(
888 std::set_difference(ReturnTypeAbiTags.begin(), ReturnTypeAbiTags.end(),
889 UsedAbiTags.begin(), UsedAbiTags.end(),
890 AdditionalAbiTags.begin()),
891 AdditionalAbiTags.end());
894 Saved = FunctionTypeDepth.push();
895 mangleNameWithAbiTags(FD, AdditionalAbiTags);
896 FunctionTypeDepth.pop(Saved);
897 Out << FunctionEncodingStream.str().substr(EncodingPositionStart);
901 extendSubstitutions(&FunctionEncodingMangler);
904void CXXNameMangler::mangleFunctionEncodingBareType(
const FunctionDecl *FD) {
905 if (FD->
hasAttr<EnableIfAttr>()) {
906 FunctionTypeDepthState Saved = FunctionTypeDepth.push();
907 Out <<
"Ua9enable_ifI";
908 for (AttrVec::const_iterator I = FD->
getAttrs().begin(),
911 EnableIfAttr *EIA = dyn_cast<EnableIfAttr>(*I);
914 if (isCompatibleWith(LangOptions::ClangABI::Ver11)) {
919 mangleExpression(EIA->getCond());
922 mangleTemplateArgExpr(EIA->getCond());
926 FunctionTypeDepth.pop(Saved);
931 if (
auto *CD = dyn_cast<CXXConstructorDecl>(FD))
932 if (
auto Inherited = CD->getInheritedConstructor())
933 FD = Inherited.getConstructor();
951 bool MangleReturnType =
false;
955 MangleReturnType =
true;
958 FD = PrimaryTemplate->getTemplatedDecl();
961 mangleBareFunctionType(FD->
getType()->
castAs<FunctionProtoType>(),
962 MangleReturnType, FD);
966bool CXXNameMangler::isStd(
const NamespaceDecl *NS) {
967 if (!Context.getEffectiveParentContext(NS)->isTranslationUnit())
971 return II && II->
isStr(
"std");
976bool CXXNameMangler::isStdNamespace(
const DeclContext *DC) {
983static const GlobalDecl
987 if (
const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)) {
996 dyn_cast<ClassTemplateSpecializationDecl>(ND)) {
997 TemplateArgs = &Spec->getTemplateArgs();
998 return GD.
getWithDecl(Spec->getSpecializedTemplate());
1003 dyn_cast<VarTemplateSpecializationDecl>(ND)) {
1004 TemplateArgs = &Spec->getTemplateArgs();
1005 return GD.
getWithDecl(Spec->getSpecializedTemplate());
1016void CXXNameMangler::mangleName(GlobalDecl GD) {
1018 if (
const VarDecl *VD = dyn_cast<VarDecl>(ND)) {
1020 AbiTagList VariableTypeAbiTags = makeVariableTypeTags(VD);
1021 if (VariableTypeAbiTags.empty()) {
1023 mangleNameWithAbiTags(VD);
1028 llvm::raw_null_ostream NullOutStream;
1029 CXXNameMangler VariableNameMangler(*
this, NullOutStream);
1030 VariableNameMangler.disableDerivedAbiTags();
1031 VariableNameMangler.mangleNameWithAbiTags(VD);
1034 const AbiTagList &UsedAbiTags =
1035 VariableNameMangler.AbiTagsRoot.getSortedUniqueUsedAbiTags();
1036 AbiTagList AdditionalAbiTags(VariableTypeAbiTags.size());
1037 AdditionalAbiTags.erase(
1038 std::set_difference(VariableTypeAbiTags.begin(),
1039 VariableTypeAbiTags.end(), UsedAbiTags.begin(),
1040 UsedAbiTags.end(), AdditionalAbiTags.begin()),
1041 AdditionalAbiTags.end());
1044 mangleNameWithAbiTags(VD, AdditionalAbiTags);
1046 mangleNameWithAbiTags(GD);
1050const RecordDecl *CXXNameMangler::GetLocalClassDecl(
const Decl *D) {
1051 const DeclContext *DC = Context.getEffectiveDeclContext(D);
1053 if (isLocalContainerContext(DC))
1054 return dyn_cast<RecordDecl>(D);
1056 DC = Context.getEffectiveDeclContext(D);
1061void CXXNameMangler::mangleNameWithAbiTags(
1062 GlobalDecl GD, ArrayRef<StringRef> AdditionalAbiTags) {
1069 const DeclContext *DC = Context.getEffectiveDeclContext(ND);
1070 bool IsLambda = isLambda(ND);
1072 if (GetLocalClassDecl(ND) &&
1073 (!IsLambda || isCompatibleWith(LangOptions::ClangABI::Ver18))) {
1074 mangleLocalName(GD, AdditionalAbiTags);
1082 if (
const NamedDecl *PrefixND = getClosurePrefix(ND)) {
1083 mangleNestedNameWithClosurePrefix(GD, PrefixND, AdditionalAbiTags);
1087 if (isLocalContainerContext(DC)) {
1088 mangleLocalName(GD, AdditionalAbiTags);
1097 const TemplateArgumentList *TemplateArgs =
nullptr;
1098 if (GlobalDecl TD =
isTemplate(GD, TemplateArgs)) {
1099 mangleUnscopedTemplateName(TD, DC, AdditionalAbiTags);
1104 mangleUnscopedName(GD, DC, AdditionalAbiTags);
1108 mangleNestedName(GD, DC, AdditionalAbiTags);
1111void CXXNameMangler::mangleModuleName(
const NamedDecl *ND) {
1114 mangleModuleNamePrefix(M->getPrimaryModuleInterfaceName());
1122void CXXNameMangler::mangleModuleNamePrefix(StringRef Name,
bool IsPartition) {
1124 if (
auto It = ModuleSubstitutions.find(Name);
1125 It != ModuleSubstitutions.end()) {
1127 mangleSeqID(It->second);
1133 auto [Prefix, SubName] = Name.rsplit(
'.');
1134 if (SubName.empty())
1137 mangleModuleNamePrefix(Prefix, IsPartition);
1138 IsPartition =
false;
1144 Out << SubName.size() << SubName;
1145 ModuleSubstitutions.insert({Name, SeqID++});
1148void CXXNameMangler::mangleTemplateName(
const TemplateDecl *TD,
1149 ArrayRef<TemplateArgument> Args) {
1150 const DeclContext *DC = Context.getEffectiveDeclContext(TD);
1153 mangleUnscopedTemplateName(TD, DC);
1156 mangleNestedName(TD, Args);
1160void CXXNameMangler::mangleUnscopedName(GlobalDecl GD,
const DeclContext *DC,
1161 ArrayRef<StringRef> AdditionalAbiTags) {
1166 if (isStdNamespace(DC)) {
1167 if (getASTContext().getTargetInfo().
getTriple().isOSSolaris()) {
1169 if (
const RecordDecl *RD = dyn_cast<RecordDecl>(ND)) {
1174 if (
const IdentifierInfo *II = RD->getIdentifier()) {
1176 if (llvm::is_contained({
"div_t",
"ldiv_t",
"lconv",
"tm"},
type)) {
1186 mangleUnqualifiedName(GD, DC, AdditionalAbiTags);
1189void CXXNameMangler::mangleUnscopedTemplateName(
1190 GlobalDecl GD,
const DeclContext *DC,
1191 ArrayRef<StringRef> AdditionalAbiTags) {
1195 if (mangleSubstitution(ND))
1199 if (
const auto *TTP = dyn_cast<TemplateTemplateParmDecl>(ND)) {
1200 assert(AdditionalAbiTags.empty() &&
1201 "template template param cannot have abi tags");
1202 mangleTemplateParameter(TTP->getDepth(), TTP->getIndex());
1204 mangleUnscopedName(GD, DC, AdditionalAbiTags);
1210 addSubstitution(ND);
1213void CXXNameMangler::mangleFloat(
const llvm::APFloat &f) {
1227 llvm::APInt valueBits = f.bitcastToAPInt();
1228 unsigned numCharacters = (valueBits.getBitWidth() + 3) / 4;
1229 assert(numCharacters != 0);
1232 SmallVector<char, 20> buffer(numCharacters);
1235 for (
unsigned stringIndex = 0; stringIndex != numCharacters; ++stringIndex) {
1237 unsigned digitBitIndex = 4 * (numCharacters - stringIndex - 1);
1240 uint64_t hexDigit = valueBits.getRawData()[digitBitIndex / 64];
1241 hexDigit >>= (digitBitIndex % 64);
1245 static const char charForHex[16] = {
1246 '0',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
1247 '8',
'9',
'a',
'b',
'c',
'd',
'e',
'f'
1249 buffer[stringIndex] = charForHex[hexDigit];
1252 Out.write(buffer.data(), numCharacters);
1255void CXXNameMangler::mangleFloatLiteral(QualType T,
const llvm::APFloat &
V) {
1262void CXXNameMangler::mangleFixedPointLiteral() {
1263 DiagnosticsEngine &Diags = Context.getDiags();
1264 Diags.
Report(diag::err_unsupported_itanium_mangling)
1265 << UnsupportedItaniumManglingKind::FixedPointLiteral;
1268void CXXNameMangler::mangleNullPointer(QualType T) {
1275void CXXNameMangler::mangleNumber(
const llvm::APSInt &
Value) {
1276 if (
Value.isSigned() &&
Value.isNegative()) {
1278 Value.abs().print(Out,
false);
1280 Value.print(Out,
false);
1284void CXXNameMangler::mangleNumber(int64_t Number) {
1294void CXXNameMangler::mangleCallOffset(int64_t NonVirtual, int64_t
Virtual) {
1302 mangleNumber(NonVirtual);
1308 mangleNumber(NonVirtual);
1314void CXXNameMangler::manglePrefix(QualType
type) {
1315 if (
const auto *TST =
type->getAs<TemplateSpecializationType>()) {
1316 if (!mangleSubstitution(QualType(TST, 0))) {
1317 mangleTemplatePrefix(TST->getTemplateName());
1322 mangleTemplateArgs(TST->getTemplateName(), TST->template_arguments());
1323 addSubstitution(QualType(TST, 0));
1325 }
else if (
const auto *DNT =
type->getAs<DependentNameType>()) {
1327 bool Clang14Compat = isCompatibleWith(LangOptions::ClangABI::Ver14);
1328 if (!Clang14Compat && mangleSubstitution(QualType(DNT, 0)))
1333 assert(DNT->getQualifier());
1334 manglePrefix(DNT->getQualifier());
1336 mangleSourceName(DNT->getIdentifier());
1339 addSubstitution(QualType(DNT, 0));
1351void CXXNameMangler::mangleUnresolvedPrefix(NestedNameSpecifier Qualifier,
1369 case NestedNameSpecifier::Kind::Null:
1370 llvm_unreachable(
"unexpected null nested name specifier");
1372 case NestedNameSpecifier::Kind::Global:
1382 case NestedNameSpecifier::Kind::MicrosoftSuper:
1383 llvm_unreachable(
"Can't mangle __super specifier");
1385 case NestedNameSpecifier::Kind::Namespace: {
1388 mangleUnresolvedPrefix(Prefix,
1392 mangleSourceNameWithAbiTags(Namespace);
1396 case NestedNameSpecifier::Kind::Type: {
1404 if (NestedNameSpecifier Prefix =
type->getPrefix()) {
1405 mangleUnresolvedPrefix(Prefix,
1412 if (mangleUnresolvedTypeOrSimpleId(QualType(
type, 0), recursive ?
"N" :
""))
1427void CXXNameMangler::mangleUnresolvedName(
1428 NestedNameSpecifier Qualifier, DeclarationName name,
1429 const TemplateArgumentLoc *TemplateArgs,
unsigned NumTemplateArgs,
1430 unsigned knownArity) {
1432 mangleUnresolvedPrefix(Qualifier);
1433 switch (
name.getNameKind()) {
1436 mangleSourceName(
name.getAsIdentifierInfo());
1441 mangleUnresolvedTypeOrSimpleId(
name.getCXXNameType());
1448 mangleOperatorName(name, knownArity);
1451 llvm_unreachable(
"Can't mangle a constructor name!");
1453 llvm_unreachable(
"Can't mangle a using directive name!");
1455 llvm_unreachable(
"Can't mangle a deduction guide name!");
1459 llvm_unreachable(
"Can't mangle Objective-C selector names here!");
1465 mangleTemplateArgs(
TemplateName(), TemplateArgs, NumTemplateArgs);
1468void CXXNameMangler::mangleUnqualifiedName(
1469 GlobalDecl GD, DeclarationName Name,
const DeclContext *DC,
1470 unsigned KnownArity, ArrayRef<StringRef> AdditionalAbiTags) {
1471 const NamedDecl *ND = cast_or_null<NamedDecl>(GD.
getDecl());
1478 mangleModuleName(ND);
1482 auto *FD = dyn_cast<FunctionDecl>(ND);
1483 auto *FTD = dyn_cast<FunctionTemplateDecl>(ND);
1485 (FTD && FTD->getTemplatedDecl()->isMemberLikeConstrainedFriend())) {
1486 if (!isCompatibleWith(LangOptions::ClangABI::Ver17))
1490 unsigned Arity = KnownArity;
1496 if (
auto *DD = dyn_cast<DecompositionDecl>(ND)) {
1503 for (
auto *BD : DD->bindings())
1504 mangleSourceName(BD->getDeclName().getAsIdentifierInfo());
1506 writeAbiTags(ND, AdditionalAbiTags);
1510 if (
auto *GD = dyn_cast<MSGuidDecl>(ND)) {
1513 SmallString<
sizeof(
"_GUID_12345678_1234_1234_1234_1234567890ab")> GUID;
1514 llvm::raw_svector_ostream GUIDOS(GUID);
1515 Context.mangleMSGuidDecl(GD, GUIDOS);
1516 Out << GUID.size() << GUID;
1520 if (
auto *TPO = dyn_cast<TemplateParamObjectDecl>(ND)) {
1523 mangleValueInTemplateArg(TPO->getType().getUnqualifiedType(),
1524 TPO->getValue(),
true);
1542 if (Context.isInternalLinkageDecl(ND))
1545 bool IsRegCall = FD &&
1549 FD && FD->
hasAttr<CUDAGlobalAttr>() &&
1551 bool IsOCLDeviceStub =
1553 DeviceKernelAttr::isOpenCLSpelling(FD->
getAttr<DeviceKernelAttr>()) &&
1556 mangleDeviceStubName(II);
1557 else if (IsOCLDeviceStub)
1558 mangleOCLDeviceStubName(II);
1560 mangleRegCallName(II);
1562 mangleSourceName(II);
1564 writeAbiTags(ND, AdditionalAbiTags);
1569 assert(ND &&
"mangling empty name without declaration");
1571 if (
const NamespaceDecl *NS = dyn_cast<NamespaceDecl>(ND)) {
1574 Out <<
"12_GLOBAL__N_1";
1579 if (
const VarDecl *VD = dyn_cast<VarDecl>(ND)) {
1581 const auto *RD = VD->getType()->castAsRecordDecl();
1592 assert(RD->isAnonymousStructOrUnion()
1593 &&
"Expected anonymous struct or union!");
1594 const FieldDecl *FD = RD->findFirstNamedDataMember();
1600 assert(FD->
getIdentifier() &&
"Data member name isn't an identifier!");
1620 "Typedef should not be in another decl context!");
1621 assert(D->getDeclName().getAsIdentifierInfo() &&
1622 "Typedef was not named!");
1623 mangleSourceName(D->getDeclName().getAsIdentifierInfo());
1624 assert(AdditionalAbiTags.empty() &&
1625 "Type cannot have additional abi tags");
1637 if (
const CXXRecordDecl *
Record = dyn_cast<CXXRecordDecl>(TD)) {
1639 Context.getDiscriminatorOverride()(Context.getASTContext(),
Record);
1645 if (
Record->isLambda() &&
1646 ((DeviceNumber && *DeviceNumber > 0) ||
1647 (!DeviceNumber &&
Record->getLambdaManglingNumber() > 0))) {
1648 assert(AdditionalAbiTags.empty() &&
1649 "Lambda type cannot have additional abi tags");
1656 unsigned UnnamedMangle =
1657 getASTContext().getManglingNumber(TD, Context.isAux());
1659 if (UnnamedMangle > 1)
1660 Out << UnnamedMangle - 2;
1662 writeAbiTags(TD, AdditionalAbiTags);
1668 unsigned AnonStructId =
1670 : Context.getAnonymousStructId(TD, dyn_cast<FunctionDecl>(DC));
1677 Str += llvm::utostr(AnonStructId);
1687 llvm_unreachable(
"Can't mangle Objective-C selector names here!");
1698 if (ND && Arity == UnknownArity) {
1702 if (
const auto *MD = dyn_cast<CXXMethodDecl>(ND))
1703 if (MD->isImplicitObjectMemberFunction())
1709 mangleOperatorName(Name, Arity);
1710 writeAbiTags(ND, AdditionalAbiTags);
1714 llvm_unreachable(
"Can't mangle a deduction guide name!");
1717 llvm_unreachable(
"Can't mangle a using directive name!");
1721void CXXNameMangler::mangleConstructorName(
1722 const CXXConstructorDecl *CCD, ArrayRef<StringRef> AdditionalAbiTags) {
1723 const CXXRecordDecl *InheritedFrom =
nullptr;
1725 const TemplateArgumentList *InheritedTemplateArgs =
nullptr;
1727 InheritedFrom = Inherited.getConstructor()->
getParent();
1728 InheritedTemplateName =
1729 TemplateName(Inherited.getConstructor()->getPrimaryTemplate());
1730 InheritedTemplateArgs =
1731 Inherited.getConstructor()->getTemplateSpecializationArgs();
1734 if (CCD == Structor)
1737 mangleCXXCtorType(
static_cast<CXXCtorType>(StructorType), InheritedFrom);
1745 if (InheritedTemplateArgs)
1746 mangleTemplateArgs(InheritedTemplateName, *InheritedTemplateArgs);
1748 writeAbiTags(CCD, AdditionalAbiTags);
1751void CXXNameMangler::mangleDestructorName(
1752 const CXXDestructorDecl *CDD, ArrayRef<StringRef> AdditionalAbiTags) {
1753 if (CDD == Structor)
1756 mangleCXXDtorType(
static_cast<CXXDtorType>(StructorType));
1762 writeAbiTags(CDD, AdditionalAbiTags);
1765void CXXNameMangler::mangleRegCallName(
const IdentifierInfo *II) {
1769 if (getASTContext().getLangOpts().RegCall4)
1770 Out << II->
getLength() +
sizeof(
"__regcall4__") - 1 <<
"__regcall4__"
1773 Out << II->
getLength() +
sizeof(
"__regcall3__") - 1 <<
"__regcall3__"
1777void CXXNameMangler::mangleDeviceStubName(
const IdentifierInfo *II) {
1781 Out << II->
getLength() +
sizeof(
"__device_stub__") - 1 <<
"__device_stub__"
1785void CXXNameMangler::mangleOCLDeviceStubName(
const IdentifierInfo *II) {
1789 StringRef OCLDeviceStubNamePrefix =
"__clang_ocl_kern_imp_";
1790 Out << II->
getLength() + OCLDeviceStubNamePrefix.size()
1791 << OCLDeviceStubNamePrefix << II->
getName();
1794void CXXNameMangler::mangleSourceName(
const IdentifierInfo *II) {
1801void CXXNameMangler::mangleNestedName(GlobalDecl GD,
const DeclContext *DC,
1802 ArrayRef<StringRef> AdditionalAbiTags,
1811 if (
const CXXMethodDecl *
Method = dyn_cast<CXXMethodDecl>(ND)) {
1812 Qualifiers MethodQuals =
Method->getMethodQualifiers();
1815 if (
Method->isExplicitObjectMemberFunction())
1818 mangleQualifiers(MethodQuals);
1819 mangleRefQualifier(
Method->getRefQualifier());
1823 const TemplateArgumentList *TemplateArgs =
nullptr;
1824 if (GlobalDecl TD =
isTemplate(GD, TemplateArgs)) {
1825 mangleTemplatePrefix(TD, NoFunction);
1828 manglePrefix(DC, NoFunction);
1829 mangleUnqualifiedName(GD, DC, AdditionalAbiTags);
1834void CXXNameMangler::mangleNestedName(
const TemplateDecl *TD,
1835 ArrayRef<TemplateArgument> Args) {
1840 mangleTemplatePrefix(TD);
1846void CXXNameMangler::mangleNestedNameWithClosurePrefix(
1847 GlobalDecl GD,
const NamedDecl *PrefixND,
1848 ArrayRef<StringRef> AdditionalAbiTags) {
1857 mangleClosurePrefix(PrefixND);
1858 mangleUnqualifiedName(GD,
nullptr, AdditionalAbiTags);
1869 if (
auto *CD = dyn_cast<CXXConstructorDecl>(DC))
1871 else if (
auto *DD = dyn_cast<CXXDestructorDecl>(DC))
1878void CXXNameMangler::mangleLocalName(GlobalDecl GD,
1879 ArrayRef<StringRef> AdditionalAbiTags) {
1887 const RecordDecl *RD = GetLocalClassDecl(D);
1888 const DeclContext *DC = Context.getEffectiveDeclContext(RD ? RD : D);
1893 AbiTagState LocalAbiTags(AbiTags);
1895 if (
const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(DC)) {
1897 }
else if (
const BlockDecl *BD = dyn_cast<BlockDecl>(DC)) {
1898 mangleBlockForPrefix(BD);
1905 LocalAbiTags.setUsedAbiTags(LocalAbiTags.getEmittedAbiTags());
1919 const CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(RD);
1921 if (
const ParmVarDecl *Parm
1923 if (
const FunctionDecl *
Func
1928 mangleNumber(
Num - 2);
1937 mangleUnqualifiedName(RD, DC, AdditionalAbiTags);
1938 }
else if (
const BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
1939 if (
const NamedDecl *PrefixND = getClosurePrefix(BD))
1940 mangleClosurePrefix(PrefixND,
true );
1942 manglePrefix(Context.getEffectiveDeclContext(BD),
true );
1943 assert(AdditionalAbiTags.empty() &&
1944 "Block cannot have additional abi tags");
1945 mangleUnqualifiedBlock(BD);
1948 mangleNestedName(GD, Context.getEffectiveDeclContext(ND),
1949 AdditionalAbiTags,
true );
1951 }
else if (
const BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
1954 if (
const ParmVarDecl *Parm
1955 = dyn_cast_or_null<ParmVarDecl>(BD->getBlockManglingContextDecl())) {
1956 if (
const FunctionDecl *
Func
1961 mangleNumber(
Num - 2);
1966 assert(AdditionalAbiTags.empty() &&
1967 "Block cannot have additional abi tags");
1968 mangleUnqualifiedBlock(BD);
1970 mangleUnqualifiedName(GD, DC, AdditionalAbiTags);
1973 if (
const NamedDecl *ND = dyn_cast<NamedDecl>(RD ? RD : D)) {
1975 if (Context.getNextDiscriminator(ND, disc)) {
1979 Out <<
"__" << disc <<
'_';
1984void CXXNameMangler::mangleBlockForPrefix(
const BlockDecl *
Block) {
1985 if (GetLocalClassDecl(
Block)) {
1986 mangleLocalName(
Block);
1989 const DeclContext *DC = Context.getEffectiveDeclContext(
Block);
1990 if (isLocalContainerContext(DC)) {
1991 mangleLocalName(
Block);
1994 if (
const NamedDecl *PrefixND = getClosurePrefix(
Block))
1995 mangleClosurePrefix(PrefixND);
1998 mangleUnqualifiedBlock(
Block);
2001void CXXNameMangler::mangleUnqualifiedBlock(
const BlockDecl *
Block) {
2004 if (Decl *Context =
Block->getBlockManglingContextDecl();
2005 Context && isCompatibleWith(LangOptions::ClangABI::Ver12) &&
2007 Context->getDeclContext()->isRecord()) {
2010 mangleSourceNameWithAbiTags(ND);
2016 unsigned Number =
Block->getBlockManglingNumber();
2038void CXXNameMangler::mangleTemplateParamDecl(
const NamedDecl *Decl) {
2040 if (
auto *Ty = dyn_cast<TemplateTypeParmDecl>(Decl)) {
2041 if (Ty->isParameterPack())
2043 const TypeConstraint *Constraint = Ty->getTypeConstraint();
2044 if (Constraint && !isCompatibleWith(LangOptions::ClangABI::Ver17)) {
2047 mangleTypeConstraint(Constraint);
2051 }
else if (
auto *Tn = dyn_cast<NonTypeTemplateParmDecl>(Decl)) {
2052 if (Tn->isExpandedParameterPack()) {
2053 for (
unsigned I = 0, N = Tn->getNumExpansionTypes(); I != N; ++I) {
2055 mangleType(Tn->getExpansionType(I));
2058 QualType T = Tn->getType();
2059 if (Tn->isParameterPack()) {
2061 if (
auto *PackExpansion = T->
getAs<PackExpansionType>())
2062 T = PackExpansion->getPattern();
2067 }
else if (
auto *Tt = dyn_cast<TemplateTemplateParmDecl>(Decl)) {
2068 if (Tt->isExpandedParameterPack()) {
2069 for (
unsigned I = 0, N = Tt->getNumExpansionTemplateParameters(); I != N;
2071 mangleTemplateParameterList(Tt->getExpansionTemplateParameters(I));
2073 if (Tt->isParameterPack())
2075 mangleTemplateParameterList(Tt->getTemplateParameters());
2080void CXXNameMangler::mangleTemplateParameterList(
2081 const TemplateParameterList *Params) {
2083 for (
auto *Param : *Params)
2084 mangleTemplateParamDecl(Param);
2085 mangleRequiresClause(Params->getRequiresClause());
2089void CXXNameMangler::mangleTypeConstraint(
2090 const TemplateDecl *
Concept, ArrayRef<TemplateArgument> Arguments) {
2091 const DeclContext *DC = Context.getEffectiveDeclContext(
Concept);
2093 mangleTemplateName(
Concept, Arguments);
2095 mangleUnscopedName(
Concept, DC);
2097 mangleNestedName(
Concept, DC);
2100void CXXNameMangler::mangleTypeConstraint(
const TypeConstraint *Constraint) {
2101 llvm::SmallVector<TemplateArgument, 8> Args;
2103 for (
const TemplateArgumentLoc &ArgLoc :
2105 Args.push_back(ArgLoc.getArgument());
2110void CXXNameMangler::mangleRequiresClause(
const Expr *RequiresClause) {
2112 if (RequiresClause && !isCompatibleWith(LangOptions::ClangABI::Ver17)) {
2114 mangleExpression(RequiresClause);
2118void CXXNameMangler::mangleLambda(
const CXXRecordDecl *Lambda) {
2122 Context && isCompatibleWith(LangOptions::ClangABI::Ver12) &&
2125 if (
const IdentifierInfo *Name =
2127 mangleSourceName(Name);
2128 const TemplateArgumentList *TemplateArgs =
nullptr;
2136 mangleLambdaSig(Lambda);
2151 Context.getDiscriminatorOverride()(Context.getASTContext(), Lambda);
2155 assert(Number > 0 &&
"Lambda should be mangled as an unnamed class");
2157 mangleNumber(Number - 2);
2161void CXXNameMangler::mangleLambdaSig(
const CXXRecordDecl *Lambda) {
2164 mangleTemplateParamDecl(D);
2168 mangleRequiresClause(TPL->getRequiresClause());
2172 mangleBareFunctionType(Proto,
false,
2176void CXXNameMangler::manglePrefix(NestedNameSpecifier Qualifier) {
2178 case NestedNameSpecifier::Kind::Null:
2179 case NestedNameSpecifier::Kind::Global:
2183 case NestedNameSpecifier::Kind::MicrosoftSuper:
2184 llvm_unreachable(
"Can't mangle __super specifier");
2186 case NestedNameSpecifier::Kind::Namespace:
2187 mangleName(
Qualifier.getAsNamespaceAndPrefix().Namespace->getNamespace());
2190 case NestedNameSpecifier::Kind::Type:
2191 manglePrefix(QualType(
Qualifier.getAsType(), 0));
2195 llvm_unreachable(
"unexpected nested name specifier");
2198void CXXNameMangler::manglePrefix(
const DeclContext *DC,
bool NoFunction) {
2211 if (NoFunction && isLocalContainerContext(DC))
2215 if (mangleSubstitution(ND))
2221 if (
const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND);
2222 const TemplateDecl *TD = FD->getPrimaryTemplate()) {
2223 mangleTemplatePrefix(TD);
2225 *FD->getTemplateSpecializationArgs());
2227 manglePrefix(Context.getEffectiveDeclContext(ND), NoFunction);
2230 addSubstitution(ND);
2235 manglePrefix(Context.getEffectiveDeclContext(ND), NoFunction);
2237 addSubstitution(ND);
2242 const TemplateArgumentList *TemplateArgs =
nullptr;
2243 if (GlobalDecl TD =
isTemplate(ND, TemplateArgs)) {
2244 mangleTemplatePrefix(TD);
2246 }
else if (
const NamedDecl *PrefixND = getClosurePrefix(ND)) {
2247 mangleClosurePrefix(PrefixND, NoFunction);
2248 mangleUnqualifiedName(ND,
nullptr);
2250 const DeclContext *DC = Context.getEffectiveDeclContext(ND);
2251 manglePrefix(DC, NoFunction);
2252 mangleUnqualifiedName(ND, DC);
2255 addSubstitution(ND);
2262 if (TemplateDecl *TD =
Template.getAsTemplateDecl())
2263 return mangleTemplatePrefix(TD);
2266 assert(
Dependent &&
"unexpected template name kind");
2270 bool Clang11Compat = isCompatibleWith(LangOptions::ClangABI::Ver11);
2271 if (!Clang11Compat && mangleSubstitution(
Template))
2274 manglePrefix(
Dependent->getQualifier());
2276 if (Clang11Compat && mangleSubstitution(
Template))
2279 if (IdentifierOrOverloadedOperator Name =
Dependent->getName();
2280 const IdentifierInfo *Id = Name.getIdentifier())
2281 mangleSourceName(Id);
2283 mangleOperatorName(Name.getOperator(), UnknownArity);
2288void CXXNameMangler::mangleTemplatePrefix(GlobalDecl GD,
2297 if (mangleSubstitution(ND))
2301 if (
const auto *TTP = dyn_cast<TemplateTemplateParmDecl>(ND)) {
2302 mangleTemplateParameter(TTP->getDepth(), TTP->getIndex());
2304 const DeclContext *DC = Context.getEffectiveDeclContext(ND);
2305 manglePrefix(DC, NoFunction);
2307 mangleUnqualifiedName(GD, DC);
2312 addSubstitution(ND);
2315const NamedDecl *CXXNameMangler::getClosurePrefix(
const Decl *ND) {
2316 if (isCompatibleWith(LangOptions::ClangABI::Ver12))
2319 const NamedDecl *Context =
nullptr;
2320 if (
auto *
Block = dyn_cast<BlockDecl>(ND)) {
2321 Context = dyn_cast_or_null<NamedDecl>(
Block->getBlockManglingContextDecl());
2322 }
else if (
auto *VD = dyn_cast<VarDecl>(ND)) {
2325 }
else if (
auto *RD = dyn_cast<CXXRecordDecl>(ND)) {
2327 Context = dyn_cast_or_null<NamedDecl>(RD->getLambdaContextDecl());
2341void CXXNameMangler::mangleClosurePrefix(
const NamedDecl *ND,
bool NoFunction) {
2344 if (mangleSubstitution(ND))
2347 const TemplateArgumentList *TemplateArgs =
nullptr;
2348 if (GlobalDecl TD =
isTemplate(ND, TemplateArgs)) {
2349 mangleTemplatePrefix(TD, NoFunction);
2352 const auto *DC = Context.getEffectiveDeclContext(ND);
2353 manglePrefix(DC, NoFunction);
2354 mangleUnqualifiedName(ND, DC);
2359 addSubstitution(ND);
2368 if (mangleSubstitution(TN))
2371 TemplateDecl *TD =
nullptr;
2381 if (
auto *TTP = dyn_cast<TemplateTemplateParmDecl>(TD))
2382 mangleTemplateParameter(TTP->getDepth(), TTP->getIndex());
2389 llvm_unreachable(
"can't mangle an overloaded template name as a <type>");
2398 mangleUnresolvedPrefix(
Dependent->getQualifier());
2399 mangleSourceName(II);
2408 SubstTemplateTemplateParmStorage *subst
2419 Out <<
"_SUBSTPACK_";
2423 llvm_unreachable(
"Unexpected DeducedTemplate");
2426 addSubstitution(TN);
2429bool CXXNameMangler::mangleUnresolvedTypeOrSimpleId(QualType Ty,
2435 case Type::Adjusted:
2437 case Type::ArrayParameter:
2439 case Type::BlockPointer:
2440 case Type::LValueReference:
2441 case Type::RValueReference:
2442 case Type::MemberPointer:
2443 case Type::ConstantArray:
2444 case Type::IncompleteArray:
2445 case Type::VariableArray:
2446 case Type::DependentSizedArray:
2447 case Type::DependentAddressSpace:
2448 case Type::DependentVector:
2449 case Type::DependentSizedExtVector:
2451 case Type::ExtVector:
2452 case Type::ConstantMatrix:
2453 case Type::DependentSizedMatrix:
2454 case Type::FunctionProto:
2455 case Type::FunctionNoProto:
2457 case Type::Attributed:
2458 case Type::BTFTagAttributed:
2459 case Type::OverflowBehavior:
2460 case Type::HLSLAttributedResource:
2461 case Type::HLSLInlineSpirv:
2463 case Type::DeducedTemplateSpecialization:
2464 case Type::PackExpansion:
2465 case Type::ObjCObject:
2466 case Type::ObjCInterface:
2467 case Type::ObjCObjectPointer:
2468 case Type::ObjCTypeParam:
2471 case Type::MacroQualified:
2473 case Type::DependentBitInt:
2474 case Type::CountAttributed:
2475 llvm_unreachable(
"type is illegal as a nested name specifier");
2477 case Type::SubstBuiltinTemplatePack:
2482 Out <<
"_SUBSTBUILTINPACK_";
2484 case Type::SubstTemplateTypeParmPack:
2489 Out <<
"_SUBSTPACK_";
2496 case Type::TypeOfExpr:
2498 case Type::Decltype:
2499 case Type::PackIndexing:
2500 case Type::TemplateTypeParm:
2501 case Type::UnaryTransform:
2514 case Type::SubstTemplateTypeParm: {
2518 if (
auto *TD = dyn_cast<TemplateDecl>(ST->getAssociatedDecl());
2520 return mangleUnresolvedTypeOrSimpleId(ST->getReplacementType(), Prefix);
2521 goto unresolvedType;
2528 case Type::PredefinedSugar:
2532 case Type::UnresolvedUsing:
2533 mangleSourceNameWithAbiTags(
2539 mangleSourceNameWithAbiTags(
2543 case Type::TemplateSpecialization: {
2544 const TemplateSpecializationType *TST =
2554 assert(TD &&
"no template for template specialization type");
2556 goto unresolvedType;
2558 mangleSourceNameWithAbiTags(TD);
2570 llvm_unreachable(
"invalid base for a template specialization type");
2573 SubstTemplateTemplateParmStorage *subst =
2584 Out <<
"_SUBSTPACK_";
2590 mangleSourceNameWithAbiTags(TD);
2600 mangleTemplateArgs(
TemplateName(), TST->template_arguments());
2604 case Type::InjectedClassName:
2605 mangleSourceNameWithAbiTags(
2609 case Type::DependentName:
2621void CXXNameMangler::mangleOperatorName(DeclarationName Name,
unsigned Arity) {
2631 llvm_unreachable(
"Not an operator name");
2654 case OO_New:
Out <<
"nw";
break;
2656 case OO_Array_New:
Out <<
"na";
break;
2658 case OO_Delete:
Out <<
"dl";
break;
2660 case OO_Array_Delete:
Out <<
"da";
break;
2664 Out << (Arity == 1?
"ps" :
"pl");
break;
2668 Out << (Arity == 1?
"ng" :
"mi");
break;
2672 Out << (Arity == 1?
"ad" :
"an");
break;
2677 Out << (Arity == 1?
"de" :
"ml");
break;
2679 case OO_Tilde:
Out <<
"co";
break;
2681 case OO_Slash:
Out <<
"dv";
break;
2683 case OO_Percent:
Out <<
"rm";
break;
2685 case OO_Pipe:
Out <<
"or";
break;
2687 case OO_Caret:
Out <<
"eo";
break;
2689 case OO_Equal:
Out <<
"aS";
break;
2691 case OO_PlusEqual:
Out <<
"pL";
break;
2693 case OO_MinusEqual:
Out <<
"mI";
break;
2695 case OO_StarEqual:
Out <<
"mL";
break;
2697 case OO_SlashEqual:
Out <<
"dV";
break;
2699 case OO_PercentEqual:
Out <<
"rM";
break;
2701 case OO_AmpEqual:
Out <<
"aN";
break;
2703 case OO_PipeEqual:
Out <<
"oR";
break;
2705 case OO_CaretEqual:
Out <<
"eO";
break;
2707 case OO_LessLess:
Out <<
"ls";
break;
2709 case OO_GreaterGreater:
Out <<
"rs";
break;
2711 case OO_LessLessEqual:
Out <<
"lS";
break;
2713 case OO_GreaterGreaterEqual:
Out <<
"rS";
break;
2715 case OO_EqualEqual:
Out <<
"eq";
break;
2717 case OO_ExclaimEqual:
Out <<
"ne";
break;
2719 case OO_Less:
Out <<
"lt";
break;
2721 case OO_Greater:
Out <<
"gt";
break;
2723 case OO_LessEqual:
Out <<
"le";
break;
2725 case OO_GreaterEqual:
Out <<
"ge";
break;
2727 case OO_Exclaim:
Out <<
"nt";
break;
2729 case OO_AmpAmp:
Out <<
"aa";
break;
2731 case OO_PipePipe:
Out <<
"oo";
break;
2733 case OO_PlusPlus:
Out <<
"pp";
break;
2735 case OO_MinusMinus:
Out <<
"mm";
break;
2737 case OO_Comma:
Out <<
"cm";
break;
2739 case OO_ArrowStar:
Out <<
"pm";
break;
2741 case OO_Arrow:
Out <<
"pt";
break;
2743 case OO_Call:
Out <<
"cl";
break;
2745 case OO_Subscript:
Out <<
"ix";
break;
2750 case OO_Conditional:
Out <<
"qu";
break;
2753 case OO_Coawait:
Out <<
"aw";
break;
2756 case OO_Spaceship:
Out <<
"ss";
break;
2760 llvm_unreachable(
"Not an overloaded operator");
2764void CXXNameMangler::mangleQualifiers(Qualifiers Quals,
const DependentAddressSpaceType *DAST) {
2783 SmallString<64> ASString;
2789 if (TargetAS != 0 ||
2791 ASString =
"AS" + llvm::utostr(TargetAS);
2794 default: llvm_unreachable(
"Not a language specific address space");
2798 case LangAS::opencl_global:
2799 ASString =
"CLglobal";
2801 case LangAS::opencl_global_device:
2802 ASString =
"CLdevice";
2804 case LangAS::opencl_global_host:
2805 ASString =
"CLhost";
2807 case LangAS::opencl_local:
2808 ASString =
"CLlocal";
2810 case LangAS::opencl_constant:
2811 ASString =
"CLconstant";
2813 case LangAS::opencl_private:
2814 ASString =
"CLprivate";
2816 case LangAS::opencl_generic:
2817 ASString =
"CLgeneric";
2821 case LangAS::sycl_global:
2822 ASString =
"SYglobal";
2824 case LangAS::sycl_global_device:
2825 ASString =
"SYdevice";
2827 case LangAS::sycl_global_host:
2828 ASString =
"SYhost";
2830 case LangAS::sycl_local:
2831 ASString =
"SYlocal";
2833 case LangAS::sycl_private:
2834 ASString =
"SYprivate";
2837 case LangAS::cuda_device:
2838 ASString =
"CUdevice";
2840 case LangAS::cuda_constant:
2841 ASString =
"CUconstant";
2843 case LangAS::cuda_shared:
2844 ASString =
"CUshared";
2847 case LangAS::ptr32_sptr:
2848 ASString =
"ptr32_sptr";
2850 case LangAS::ptr32_uptr:
2854 if (!getASTContext().getTargetInfo().
getTriple().isOSzOS())
2855 ASString =
"ptr32_uptr";
2862 if (!ASString.empty())
2863 mangleVendorQualifier(ASString);
2876 mangleVendorQualifier(
"__weak");
2880 mangleVendorQualifier(
"__unaligned");
2884 mangleVendorQualifier(
"__ptrauth");
2894 << unsigned(PtrAuth.isAddressDiscriminated())
2897 << PtrAuth.getExtraDiscriminator()
2912 mangleVendorQualifier(
"__strong");
2916 mangleVendorQualifier(
"__autoreleasing");
2939void CXXNameMangler::mangleVendorQualifier(StringRef name) {
2943void CXXNameMangler::mangleVendorType(StringRef name) {
2950 switch (RefQualifier) {
2964void CXXNameMangler::mangleObjCMethodName(
const ObjCMethodDecl *MD) {
2965 Context.mangleObjCMethodNameAsSourceName(MD, Out);
2990 if (
auto *DeducedTST = Ty->
getAs<DeducedTemplateSpecializationType>())
2991 if (DeducedTST->getDeducedType().isNull())
2996void CXXNameMangler::mangleType(QualType T) {
3036 if (
const TemplateSpecializationType *TST
3037 = dyn_cast<TemplateSpecializationType>(T))
3038 if (!TST->isTypeAlias())
3053 auto [ty, quals] = T.
split();
3055 bool isSubstitutable =
3057 if (isSubstitutable && mangleSubstitution(T))
3064 quals = Qualifiers();
3070 if (quals || ty->isDependentAddressSpaceType()) {
3071 if (
const DependentAddressSpaceType *DAST =
3072 dyn_cast<DependentAddressSpaceType>(ty)) {
3074 mangleQualifiers(Quals, DAST);
3075 mangleType(QualType(Ty, 0));
3077 mangleQualifiers(quals);
3081 mangleType(QualType(ty, 0));
3084 switch (ty->getTypeClass()) {
3085#define ABSTRACT_TYPE(CLASS, PARENT)
3086#define NON_CANONICAL_TYPE(CLASS, PARENT) \
3088 llvm_unreachable("can't mangle non-canonical type " #CLASS "Type"); \
3090#define TYPE(CLASS, PARENT) \
3092 mangleType(static_cast<const CLASS##Type*>(ty)); \
3094#include "clang/AST/TypeNodes.inc"
3099 if (isSubstitutable)
3103void CXXNameMangler::mangleCXXRecordDecl(
const CXXRecordDecl *
Record,
3104 bool SuppressSubstitution) {
3105 if (mangleSubstitution(
Record))
3108 if (SuppressSubstitution)
3113void CXXNameMangler::mangleType(
const BuiltinType *T) {
3155 std::string type_name;
3159 if (NormalizeIntegers && T->
isInteger()) {
3161 switch (getASTContext().getTypeSize(T)) {
3165 if (mangleSubstitution(BuiltinType::SChar))
3168 addSubstitution(BuiltinType::SChar);
3171 if (mangleSubstitution(BuiltinType::Short))
3174 addSubstitution(BuiltinType::Short);
3177 if (mangleSubstitution(BuiltinType::Int))
3180 addSubstitution(BuiltinType::Int);
3183 if (mangleSubstitution(BuiltinType::Long))
3186 addSubstitution(BuiltinType::Long);
3189 if (mangleSubstitution(BuiltinType::Int128))
3192 addSubstitution(BuiltinType::Int128);
3195 llvm_unreachable(
"Unknown integer size for normalization");
3198 switch (getASTContext().getTypeSize(T)) {
3200 if (mangleSubstitution(BuiltinType::UChar))
3203 addSubstitution(BuiltinType::UChar);
3206 if (mangleSubstitution(BuiltinType::UShort))
3209 addSubstitution(BuiltinType::UShort);
3212 if (mangleSubstitution(BuiltinType::UInt))
3215 addSubstitution(BuiltinType::UInt);
3218 if (mangleSubstitution(BuiltinType::ULong))
3221 addSubstitution(BuiltinType::ULong);
3224 if (mangleSubstitution(BuiltinType::UInt128))
3227 addSubstitution(BuiltinType::UInt128);
3230 llvm_unreachable(
"Unknown integer size for normalization");
3236 case BuiltinType::Void:
3239 case BuiltinType::Bool:
3242 case BuiltinType::Char_U:
3243 case BuiltinType::Char_S:
3246 case BuiltinType::UChar:
3249 case BuiltinType::UShort:
3252 case BuiltinType::UInt:
3255 case BuiltinType::ULong:
3258 case BuiltinType::ULongLong:
3261 case BuiltinType::UInt128:
3264 case BuiltinType::SChar:
3267 case BuiltinType::WChar_S:
3268 case BuiltinType::WChar_U:
3271 case BuiltinType::Char8:
3274 case BuiltinType::Char16:
3277 case BuiltinType::Char32:
3280 case BuiltinType::Short:
3283 case BuiltinType::Int:
3286 case BuiltinType::Long:
3289 case BuiltinType::LongLong:
3292 case BuiltinType::Int128:
3295 case BuiltinType::Float16:
3298 case BuiltinType::ShortAccum:
3301 case BuiltinType::Accum:
3304 case BuiltinType::LongAccum:
3307 case BuiltinType::UShortAccum:
3310 case BuiltinType::UAccum:
3313 case BuiltinType::ULongAccum:
3316 case BuiltinType::ShortFract:
3319 case BuiltinType::Fract:
3322 case BuiltinType::LongFract:
3325 case BuiltinType::UShortFract:
3328 case BuiltinType::UFract:
3331 case BuiltinType::ULongFract:
3334 case BuiltinType::SatShortAccum:
3337 case BuiltinType::SatAccum:
3340 case BuiltinType::SatLongAccum:
3343 case BuiltinType::SatUShortAccum:
3346 case BuiltinType::SatUAccum:
3349 case BuiltinType::SatULongAccum:
3352 case BuiltinType::SatShortFract:
3355 case BuiltinType::SatFract:
3358 case BuiltinType::SatLongFract:
3361 case BuiltinType::SatUShortFract:
3364 case BuiltinType::SatUFract:
3367 case BuiltinType::SatULongFract:
3370 case BuiltinType::Half:
3373 case BuiltinType::Float:
3376 case BuiltinType::Double:
3379 case BuiltinType::LongDouble: {
3380 const TargetInfo *TI =
3381 getASTContext().getLangOpts().OpenMP &&
3382 getASTContext().getLangOpts().OpenMPIsTargetDevice
3383 ? getASTContext().getAuxTargetInfo()
3384 : &getASTContext().getTargetInfo();
3388 case BuiltinType::Float128: {
3389 const TargetInfo *TI =
3390 getASTContext().getLangOpts().OpenMP &&
3391 getASTContext().getLangOpts().OpenMPIsTargetDevice
3392 ? getASTContext().getAuxTargetInfo()
3393 : &getASTContext().getTargetInfo();
3397 case BuiltinType::BFloat16: {
3398 const TargetInfo *TI =
3399 ((getASTContext().getLangOpts().OpenMP &&
3400 getASTContext().getLangOpts().OpenMPIsTargetDevice) ||
3401 getASTContext().getLangOpts().SYCLIsDevice)
3402 ? getASTContext().getAuxTargetInfo()
3403 : &getASTContext().getTargetInfo();
3407 case BuiltinType::Ibm128: {
3408 const TargetInfo *TI = &getASTContext().getTargetInfo();
3412 case BuiltinType::NullPtr:
3416#define BUILTIN_TYPE(Id, SingletonId)
3417#define PLACEHOLDER_TYPE(Id, SingletonId) \
3418 case BuiltinType::Id:
3419#include "clang/AST/BuiltinTypes.def"
3420 case BuiltinType::Dependent:
3422 llvm_unreachable(
"mangling a placeholder type");
3424 case BuiltinType::ObjCId:
3425 Out <<
"11objc_object";
3427 case BuiltinType::ObjCClass:
3428 Out <<
"10objc_class";
3430 case BuiltinType::ObjCSel:
3431 Out <<
"13objc_selector";
3433#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
3434 case BuiltinType::Id: \
3435 type_name = "ocl_" #ImgType "_" #Suffix; \
3436 Out << type_name.size() << type_name; \
3438#include "clang/Basic/OpenCLImageTypes.def"
3439 case BuiltinType::OCLSampler:
3440 Out <<
"11ocl_sampler";
3442 case BuiltinType::OCLEvent:
3443 Out <<
"9ocl_event";
3445 case BuiltinType::OCLClkEvent:
3446 Out <<
"12ocl_clkevent";
3448 case BuiltinType::OCLQueue:
3449 Out <<
"9ocl_queue";
3451 case BuiltinType::OCLReserveID:
3452 Out <<
"13ocl_reserveid";
3454#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
3455 case BuiltinType::Id: \
3456 type_name = "ocl_" #ExtType; \
3457 Out << type_name.size() << type_name; \
3459#include "clang/Basic/OpenCLExtensionTypes.def"
3463#define SVE_VECTOR_TYPE(Name, MangledName, Id, SingletonId) \
3464 case BuiltinType::Id: \
3465 if (T->getKind() == BuiltinType::SveBFloat16 && \
3466 isCompatibleWith(LangOptions::ClangABI::Ver17)) { \
3468 mangleVendorType("__SVBFloat16_t"); \
3470 type_name = #MangledName; \
3471 Out << (type_name == #Name ? "u" : "") << type_name.size() << type_name; \
3474#define SVE_PREDICATE_TYPE(Name, MangledName, Id, SingletonId) \
3475 case BuiltinType::Id: \
3476 type_name = #MangledName; \
3477 Out << (type_name == #Name ? "u" : "") << type_name.size() << type_name; \
3479#define SVE_OPAQUE_TYPE(Name, MangledName, Id, SingletonId) \
3480 case BuiltinType::Id: \
3481 type_name = #MangledName; \
3482 Out << (type_name == #Name ? "u" : "") << type_name.size() << type_name; \
3484#define SVE_SCALAR_TYPE(Name, MangledName, Id, SingletonId, Bits) \
3485 case BuiltinType::Id: \
3486 type_name = #MangledName; \
3487 Out << (type_name == #Name ? "u" : "") << type_name.size() << type_name; \
3489#include "clang/Basic/AArch64ACLETypes.def"
3490#define PPC_VECTOR_TYPE(Name, Id, Size) \
3491 case BuiltinType::Id: \
3492 mangleVendorType(#Name); \
3494#include "clang/Basic/PPCTypes.def"
3496#define RVV_TYPE(Name, Id, SingletonId) \
3497 case BuiltinType::Id: \
3498 mangleVendorType(Name); \
3500#include "clang/Basic/RISCVVTypes.def"
3501#define WASM_REF_TYPE(InternalName, MangledName, Id, SingletonId, AS) \
3502 case BuiltinType::Id: \
3503 mangleVendorType(MangledName); \
3505#include "clang/Basic/WebAssemblyReferenceTypes.def"
3506#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) \
3507 case BuiltinType::Id: \
3508 mangleVendorType(Name); \
3510#include "clang/Basic/AMDGPUTypes.def"
3511#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) \
3512 case BuiltinType::Id: \
3513 mangleVendorType(#Name); \
3515#include "clang/Basic/HLSLIntangibleTypes.def"
3519StringRef CXXNameMangler::getCallingConvQualifierName(
CallingConv CC) {
3539#define CC_VLS_CASE(ABI_VLEN) case CC_RISCVVLSCall_##ABI_VLEN:
3575 return "swiftasynccall";
3577 llvm_unreachable(
"bad calling convention");
3580void CXXNameMangler::mangleExtFunctionInfo(
const FunctionType *T) {
3582 if (T->
getExtInfo() == FunctionType::ExtInfo())
3589 StringRef CCQualifier = getCallingConvQualifierName(T->
getExtInfo().
getCC());
3590 if (!CCQualifier.empty())
3591 mangleVendorQualifier(CCQualifier);
3624 llvm_unreachable(
"Unrecognised SME attribute");
3639void CXXNameMangler::mangleSMEAttrs(
unsigned SMEAttrs) {
3659 Out <<
"Lj" <<
static_cast<unsigned>(Bitmask) <<
"EE";
3663CXXNameMangler::mangleExtParameterInfo(FunctionProtoType::ExtParameterInfo PI) {
3670 case ParameterABI::Ordinary:
3674 case ParameterABI::HLSLOut:
3675 case ParameterABI::HLSLInOut:
3680 case ParameterABI::SwiftContext:
3681 case ParameterABI::SwiftAsyncContext:
3682 case ParameterABI::SwiftErrorResult:
3683 case ParameterABI::SwiftIndirectResult:
3689 mangleVendorQualifier(
"ns_consumed");
3692 mangleVendorQualifier(
"noescape");
3698void CXXNameMangler::mangleType(
const FunctionProtoType *T) {
3702 Out <<
"11__SME_ATTRSI";
3704 mangleExtFunctionInfo(T);
3721 mangleType(ExceptTy);
3732 mangleBareFunctionType(T,
true);
3739 mangleSMEAttrs(SMEAttrs);
3742void CXXNameMangler::mangleType(
const FunctionNoProtoType *T) {
3748 FunctionTypeDepthState saved = FunctionTypeDepth.push();
3750 FunctionTypeDepth.enterFunctionDeclSuffix();
3752 FunctionTypeDepth.leaveFunctionDeclSuffix();
3754 FunctionTypeDepth.pop(saved);
3758void CXXNameMangler::mangleBareFunctionType(
const FunctionProtoType *Proto,
3759 bool MangleReturnType,
3760 const FunctionDecl *FD) {
3763 FunctionTypeDepthState saved = FunctionTypeDepth.push();
3766 if (MangleReturnType) {
3767 FunctionTypeDepth.enterFunctionDeclSuffix();
3771 mangleVendorQualifier(
"ns_returns_retained");
3776 auto SplitReturnTy = ReturnTy.
split();
3778 ReturnTy = getASTContext().getQualifiedType(SplitReturnTy);
3780 mangleType(ReturnTy);
3782 FunctionTypeDepth.leaveFunctionDeclSuffix();
3790 for (
unsigned I = 0, E = Proto->
getNumParams(); I != E; ++I) {
3804 assert(Attr->getType() <= 9 && Attr->getType() >= 0);
3805 if (Attr->isDynamic())
3806 Out <<
"U25pass_dynamic_object_size" << Attr->getType();
3808 Out <<
"U17pass_object_size" << Attr->getType();
3819 FunctionTypeDepth.enterFunctionDeclSuffix();
3823 FunctionTypeDepth.pop(saved);
3828void CXXNameMangler::mangleType(
const UnresolvedUsingType *T) {
3834void CXXNameMangler::mangleType(
const EnumType *T) {
3835 mangleType(
static_cast<const TagType*
>(T));
3837void CXXNameMangler::mangleType(
const RecordType *T) {
3838 mangleType(
static_cast<const TagType*
>(T));
3840void CXXNameMangler::mangleType(
const TagType *T) {
3841 mangleName(T->getDecl()->getDefinitionOrSelf());
3847void CXXNameMangler::mangleType(
const ConstantArrayType *T) {
3851void CXXNameMangler::mangleType(
const VariableArrayType *T) {
3859void CXXNameMangler::mangleType(
const DependentSizedArrayType *T) {
3869void CXXNameMangler::mangleType(
const IncompleteArrayType *T) {
3876void CXXNameMangler::mangleType(
const MemberPointerType *T) {
3879 mangleCXXRecordDecl(RD);
3883 if (
const FunctionProtoType *FPT = dyn_cast<FunctionProtoType>(PointeeType)) {
3904 mangleType(PointeeType);
3908void CXXNameMangler::mangleType(
const TemplateTypeParmType *T) {
3909 mangleTemplateParameter(T->getDepth(), T->getIndex());
3913void CXXNameMangler::mangleType(
const SubstTemplateTypeParmPackType *T) {
3918 Out <<
"_SUBSTPACK_";
3921void CXXNameMangler::mangleType(
const SubstBuiltinTemplatePackType *T) {
3926 Out <<
"_SUBSTBUILTINPACK_";
3930void CXXNameMangler::mangleType(
const PointerType *T) {
3934void CXXNameMangler::mangleType(
const ObjCObjectPointerType *T) {
3940void CXXNameMangler::mangleType(
const LValueReferenceType *T) {
3946void CXXNameMangler::mangleType(
const RValueReferenceType *T) {
3952void CXXNameMangler::mangleType(
const ComplexType *T) {
3960void CXXNameMangler::mangleNeonVectorType(
const VectorType *T) {
3962 assert(EltType->
isBuiltinType() &&
"Neon vector element not a BuiltinType");
3963 const char *EltName =
nullptr;
3966 case BuiltinType::SChar:
3967 case BuiltinType::UChar:
3968 EltName =
"poly8_t";
3970 case BuiltinType::Short:
3971 case BuiltinType::UShort:
3972 EltName =
"poly16_t";
3974 case BuiltinType::LongLong:
3975 case BuiltinType::ULongLong:
3976 EltName =
"poly64_t";
3978 default: llvm_unreachable(
"unexpected Neon polynomial vector element type");
3982 case BuiltinType::SChar: EltName =
"int8_t";
break;
3983 case BuiltinType::UChar: EltName =
"uint8_t";
break;
3984 case BuiltinType::Short: EltName =
"int16_t";
break;
3985 case BuiltinType::UShort: EltName =
"uint16_t";
break;
3986 case BuiltinType::Int: EltName =
"int32_t";
break;
3987 case BuiltinType::UInt: EltName =
"uint32_t";
break;
3988 case BuiltinType::LongLong: EltName =
"int64_t";
break;
3989 case BuiltinType::ULongLong: EltName =
"uint64_t";
break;
3990 case BuiltinType::Double: EltName =
"float64_t";
break;
3991 case BuiltinType::Float: EltName =
"float32_t";
break;
3992 case BuiltinType::Half: EltName =
"float16_t";
break;
3993 case BuiltinType::BFloat16: EltName =
"bfloat16_t";
break;
3994 case BuiltinType::MFloat8:
3995 EltName =
"mfloat8_t";
3998 llvm_unreachable(
"unexpected Neon vector element type");
4001 const char *BaseName =
nullptr;
4003 getASTContext().getTypeSize(EltType));
4005 BaseName =
"__simd64_";
4007 assert(BitSize == 128 &&
"Neon vector type not 64 or 128 bits");
4008 BaseName =
"__simd128_";
4010 Out << strlen(BaseName) + strlen(EltName);
4011 Out << BaseName << EltName;
4014void CXXNameMangler::mangleNeonVectorType(
const DependentVectorType *T) {
4015 DiagnosticsEngine &Diags = Context.getDiags();
4017 << UnsupportedItaniumManglingKind::DependentNeonVector;
4022 case BuiltinType::SChar:
4024 case BuiltinType::Short:
4026 case BuiltinType::Int:
4028 case BuiltinType::Long:
4029 case BuiltinType::LongLong:
4031 case BuiltinType::UChar:
4033 case BuiltinType::UShort:
4035 case BuiltinType::UInt:
4037 case BuiltinType::ULong:
4038 case BuiltinType::ULongLong:
4040 case BuiltinType::Half:
4042 case BuiltinType::Float:
4044 case BuiltinType::Double:
4046 case BuiltinType::BFloat16:
4048 case BuiltinType::MFloat8:
4051 llvm_unreachable(
"Unexpected vector element base type");
4058void CXXNameMangler::mangleAArch64NeonVectorType(
const VectorType *T) {
4060 assert(EltType->
isBuiltinType() &&
"Neon vector element not a BuiltinType");
4065 assert((BitSize == 64 || BitSize == 128) &&
4066 "Neon vector type not 64 or 128 bits");
4071 case BuiltinType::UChar:
4074 case BuiltinType::UShort:
4077 case BuiltinType::ULong:
4078 case BuiltinType::ULongLong:
4082 llvm_unreachable(
"unexpected Neon polynomial vector element type");
4088 (
"__" + EltName +
"x" + Twine(T->
getNumElements()) +
"_t").str();
4091void CXXNameMangler::mangleAArch64NeonVectorType(
const DependentVectorType *T) {
4092 DiagnosticsEngine &Diags = Context.getDiags();
4094 << UnsupportedItaniumManglingKind::DependentNeonVector;
4121void CXXNameMangler::mangleAArch64FixedSveVectorType(
const VectorType *T) {
4122 assert((T->
getVectorKind() == VectorKind::SveFixedLengthData ||
4123 T->
getVectorKind() == VectorKind::SveFixedLengthPredicate) &&
4124 "expected fixed-length SVE vector!");
4128 "expected builtin type for fixed-length SVE vector!");
4132 case BuiltinType::SChar:
4135 case BuiltinType::UChar: {
4142 case BuiltinType::Short:
4145 case BuiltinType::UShort:
4148 case BuiltinType::Int:
4151 case BuiltinType::UInt:
4154 case BuiltinType::Long:
4157 case BuiltinType::ULong:
4160 case BuiltinType::Half:
4163 case BuiltinType::Float:
4166 case BuiltinType::Double:
4169 case BuiltinType::BFloat16:
4173 llvm_unreachable(
"unexpected element type for fixed-length SVE vector!");
4176 unsigned VecSizeInBits = getASTContext().getTypeInfo(T).Width;
4178 if (T->
getVectorKind() == VectorKind::SveFixedLengthPredicate)
4181 Out <<
"9__SVE_VLSI";
4182 mangleVendorType(TypeName);
4183 Out <<
"Lj" << VecSizeInBits <<
"EE";
4186void CXXNameMangler::mangleAArch64FixedSveVectorType(
4187 const DependentVectorType *T) {
4188 DiagnosticsEngine &Diags = Context.getDiags();
4190 << UnsupportedItaniumManglingKind::DependentFixedLengthSVEVector;
4193void CXXNameMangler::mangleRISCVFixedRVVVectorType(
const VectorType *T) {
4194 assert((T->
getVectorKind() == VectorKind::RVVFixedLengthData ||
4199 "expected fixed-length RVV vector!");
4203 "expected builtin type for fixed-length RVV vector!");
4205 SmallString<20> TypeNameStr;
4206 llvm::raw_svector_ostream TypeNameOS(TypeNameStr);
4207 TypeNameOS <<
"__rvv_";
4209 case BuiltinType::SChar:
4210 TypeNameOS <<
"int8";
4212 case BuiltinType::UChar:
4214 TypeNameOS <<
"uint8";
4216 TypeNameOS <<
"bool";
4218 case BuiltinType::Short:
4219 TypeNameOS <<
"int16";
4221 case BuiltinType::UShort:
4222 TypeNameOS <<
"uint16";
4224 case BuiltinType::Int:
4225 TypeNameOS <<
"int32";
4227 case BuiltinType::UInt:
4228 TypeNameOS <<
"uint32";
4230 case BuiltinType::Long:
4231 case BuiltinType::LongLong:
4232 TypeNameOS <<
"int64";
4234 case BuiltinType::ULong:
4235 case BuiltinType::ULongLong:
4236 TypeNameOS <<
"uint64";
4238 case BuiltinType::Float16:
4239 TypeNameOS <<
"float16";
4241 case BuiltinType::Float:
4242 TypeNameOS <<
"float32";
4244 case BuiltinType::Double:
4245 TypeNameOS <<
"float64";
4247 case BuiltinType::BFloat16:
4248 TypeNameOS <<
"bfloat16";
4251 llvm_unreachable(
"unexpected element type for fixed-length RVV vector!");
4254 unsigned VecSizeInBits;
4256 case VectorKind::RVVFixedLengthMask_1:
4259 case VectorKind::RVVFixedLengthMask_2:
4262 case VectorKind::RVVFixedLengthMask_4:
4266 VecSizeInBits = getASTContext().getTypeInfo(T).Width;
4271 auto VScale = getASTContext().getTargetInfo().getVScaleRange(
4272 getASTContext().getLangOpts(),
4273 TargetInfo::ArmStreamingKind::NotStreaming);
4274 unsigned VLen = VScale->first * llvm::RISCV::RVVBitsPerBlock;
4278 if (VecSizeInBits >= VLen)
4279 TypeNameOS << (VecSizeInBits / VLen);
4281 TypeNameOS <<
'f' << (VLen / VecSizeInBits);
4283 TypeNameOS << (VLen / VecSizeInBits);
4287 Out <<
"9__RVV_VLSI";
4288 mangleVendorType(TypeNameStr);
4289 Out <<
"Lj" << VecSizeInBits <<
"EE";
4292void CXXNameMangler::mangleRISCVFixedRVVVectorType(
4293 const DependentVectorType *T) {
4294 DiagnosticsEngine &Diags = Context.getDiags();
4296 << UnsupportedItaniumManglingKind::DependentFixedLengthRVVVectorType;
4307void CXXNameMangler::mangleType(
const VectorType *T) {
4310 llvm::Triple
Target = getASTContext().getTargetInfo().getTriple();
4311 llvm::Triple::ArchType
Arch =
4312 getASTContext().getTargetInfo().getTriple().getArch();
4313 if ((
Arch == llvm::Triple::aarch64 ||
4314 Arch == llvm::Triple::aarch64_be) && !
Target.isOSDarwin())
4315 mangleAArch64NeonVectorType(T);
4317 mangleNeonVectorType(T);
4319 }
else if (T->
getVectorKind() == VectorKind::SveFixedLengthData ||
4320 T->
getVectorKind() == VectorKind::SveFixedLengthPredicate) {
4321 mangleAArch64FixedSveVectorType(T);
4323 }
else if (T->
getVectorKind() == VectorKind::RVVFixedLengthData ||
4328 mangleRISCVFixedRVVVectorType(T);
4340void CXXNameMangler::mangleType(
const DependentVectorType *T) {
4343 llvm::Triple
Target = getASTContext().getTargetInfo().getTriple();
4344 llvm::Triple::ArchType
Arch =
4345 getASTContext().getTargetInfo().getTriple().getArch();
4346 if ((
Arch == llvm::Triple::aarch64 ||
Arch == llvm::Triple::aarch64_be) &&
4348 mangleAArch64NeonVectorType(T);
4350 mangleNeonVectorType(T);
4352 }
else if (T->
getVectorKind() == VectorKind::SveFixedLengthData ||
4353 T->
getVectorKind() == VectorKind::SveFixedLengthPredicate) {
4354 mangleAArch64FixedSveVectorType(T);
4356 }
else if (T->
getVectorKind() == VectorKind::RVVFixedLengthData) {
4357 mangleRISCVFixedRVVVectorType(T);
4372void CXXNameMangler::mangleType(
const ExtVectorType *T) {
4373 mangleType(
static_cast<const VectorType*
>(T));
4375void CXXNameMangler::mangleType(
const DependentSizedExtVectorType *T) {
4382void CXXNameMangler::mangleType(
const ConstantMatrixType *T) {
4386 mangleVendorType(
"matrix_type");
4389 auto &ASTCtx = getASTContext();
4390 unsigned BitWidth = ASTCtx.getTypeSize(ASTCtx.getSizeType());
4391 llvm::APSInt Rows(BitWidth);
4393 mangleIntegerLiteral(ASTCtx.getSizeType(), Rows);
4394 llvm::APSInt Columns(BitWidth);
4396 mangleIntegerLiteral(ASTCtx.getSizeType(), Columns);
4401void CXXNameMangler::mangleType(
const DependentSizedMatrixType *T) {
4404 mangleVendorType(
"matrix_type");
4413void CXXNameMangler::mangleType(
const DependentAddressSpaceType *T) {
4415 mangleQualifiers(split.
Quals, T);
4416 mangleType(QualType(split.
Ty, 0));
4419void CXXNameMangler::mangleType(
const PackExpansionType *T) {
4422 mangleType(T->getPattern());
4425void CXXNameMangler::mangleType(
const PackIndexingType *T) {
4428 mangleType(T->getPattern());
4429 mangleExpression(T->getIndexExpr());
4432void CXXNameMangler::mangleType(
const ObjCInterfaceType *T) {
4436void CXXNameMangler::mangleType(
const ObjCObjectType *T) {
4438 if (T->isKindOfType())
4439 Out <<
"U8__kindof";
4441 if (!T->qual_empty()) {
4443 SmallString<64> QualStr;
4444 llvm::raw_svector_ostream QualOS(QualStr);
4445 QualOS <<
"objcproto";
4446 for (
const auto *I : T->quals()) {
4447 StringRef
name = I->getName();
4450 mangleVendorQualifier(QualStr);
4453 mangleType(T->getBaseType());
4455 if (T->isSpecialized()) {
4458 for (
auto typeArg : T->getTypeArgs())
4459 mangleType(typeArg);
4464void CXXNameMangler::mangleType(
const BlockPointerType *T) {
4465 Out <<
"U13block_pointer";
4469void CXXNameMangler::mangleType(
const InjectedClassNameType *T) {
4474 T->getDecl()->getCanonicalTemplateSpecializationType(getASTContext()));
4477void CXXNameMangler::mangleType(
const TemplateSpecializationType *T) {
4478 if (TemplateDecl *TD = T->getTemplateName().getAsTemplateDecl()) {
4479 mangleTemplateName(TD, T->template_arguments());
4482 mangleTemplatePrefix(T->getTemplateName());
4487 mangleTemplateArgs(T->getTemplateName(), T->template_arguments());
4492void CXXNameMangler::mangleType(
const DependentNameType *T) {
4503 switch (T->getKeyword()) {
4504 case ElaboratedTypeKeyword::None:
4505 case ElaboratedTypeKeyword::Typename:
4507 case ElaboratedTypeKeyword::Struct:
4508 case ElaboratedTypeKeyword::Class:
4509 case ElaboratedTypeKeyword::Interface:
4512 case ElaboratedTypeKeyword::Union:
4515 case ElaboratedTypeKeyword::Enum:
4521 manglePrefix(T->getQualifier());
4522 mangleSourceName(T->getIdentifier());
4526void CXXNameMangler::mangleType(
const TypeOfType *T) {
4532void CXXNameMangler::mangleType(
const TypeOfExprType *T) {
4538void CXXNameMangler::mangleType(
const DecltypeType *T) {
4539 Expr *E = T->getUnderlyingExpr();
4558 mangleExpression(E);
4562void CXXNameMangler::mangleType(
const UnaryTransformType *T) {
4565 if (T->isDependentType()) {
4566 StringRef BuiltinName;
4567 switch (T->getUTTKind()) {
4568#define TRANSFORM_TYPE_TRAIT_DEF(Enum, Trait) \
4569 case UnaryTransformType::Enum: \
4570 BuiltinName = "__" #Trait; \
4572#include "clang/Basic/TransformTypeTraits.def"
4574 mangleVendorType(BuiltinName);
4578 mangleType(T->getBaseType());
4582void CXXNameMangler::mangleType(
const AutoType *T) {
4583 assert(T->getDeducedType().isNull() &&
4584 "Deduced AutoType shouldn't be handled here!");
4585 assert(T->getKeyword() != AutoTypeKeyword::GNUAutoType &&
4586 "shouldn't need to mangle __auto_type!");
4591 if (T->isConstrained() && !isCompatibleWith(LangOptions::ClangABI::Ver17)) {
4592 Out << (T->isDecltypeAuto() ?
"DK" :
"Dk");
4593 mangleTypeConstraint(T->getTypeConstraintConcept(),
4594 T->getTypeConstraintArguments());
4596 Out << (T->isDecltypeAuto() ?
"Dc" :
"Da");
4600void CXXNameMangler::mangleType(
const DeducedTemplateSpecializationType *T) {
4601 QualType
Deduced = T->getDeducedType();
4607 "shouldn't form deduced TST unless we know we have a template");
4611void CXXNameMangler::mangleType(
const AtomicType *T) {
4618void CXXNameMangler::mangleType(
const PipeType *T) {
4625void CXXNameMangler::mangleType(
const OverflowBehaviorType *T) {
4628 if (T->isWrapKind()) {
4629 Out <<
"U8ObtWrap_";
4631 Out <<
"U8ObtTrap_";
4633 mangleType(T->getUnderlyingType());
4636void CXXNameMangler::mangleType(
const BitIntType *T) {
4643void CXXNameMangler::mangleType(
const DependentBitIntType *T) {
4652void CXXNameMangler::mangleType(
const ArrayParameterType *T) {
4656void CXXNameMangler::mangleType(
const HLSLAttributedResourceType *T) {
4657 llvm::SmallString<64> Str(
"_Res");
4658 const HLSLAttributedResourceType::Attributes &Attrs = T->getAttrs();
4660 switch (Attrs.ResourceClass) {
4661 case llvm::dxil::ResourceClass::UAV:
4664 case llvm::dxil::ResourceClass::SRV:
4667 case llvm::dxil::ResourceClass::CBuffer:
4670 case llvm::dxil::ResourceClass::Sampler:
4676 if (Attrs.RawBuffer)
4678 if (Attrs.IsCounter)
4682 if (T->hasContainedType())
4684 mangleVendorQualifier(Str);
4686 if (T->hasContainedType()) {
4687 mangleType(T->getContainedType());
4689 mangleType(T->getWrappedType());
4692void CXXNameMangler::mangleType(
const HLSLInlineSpirvType *T) {
4693 SmallString<20> TypeNameStr;
4694 llvm::raw_svector_ostream TypeNameOS(TypeNameStr);
4696 TypeNameOS <<
"spirv_type";
4698 TypeNameOS <<
"_" << T->getOpcode();
4699 TypeNameOS <<
"_" << T->getSize();
4700 TypeNameOS <<
"_" << T->getAlignment();
4702 mangleVendorType(TypeNameStr);
4704 for (
auto &Operand : T->getOperands()) {
4705 using SpirvOperandKind = SpirvOperand::SpirvOperandKind;
4708 case SpirvOperandKind::ConstantId:
4709 mangleVendorQualifier(
"_Const");
4710 mangleIntegerLiteral(
Operand.getResultType(),
4711 llvm::APSInt(
Operand.getValue()));
4713 case SpirvOperandKind::Literal:
4714 mangleVendorQualifier(
"_Lit");
4715 mangleIntegerLiteral(Context.getASTContext().
IntTy,
4716 llvm::APSInt(
Operand.getValue()));
4718 case SpirvOperandKind::TypeId:
4719 mangleVendorQualifier(
"_Type");
4720 mangleType(
Operand.getResultType());
4723 llvm_unreachable(
"Invalid SpirvOperand kind");
4726 TypeNameOS <<
Operand.getKind();
4730void CXXNameMangler::mangleIntegerLiteral(QualType T,
4731 const llvm::APSInt &
Value) {
4738 Out << (
Value.getBoolValue() ?
'1' :
'0');
4740 mangleNumber(
Value);
4745void CXXNameMangler::mangleMemberExprBase(
const Expr *Base,
bool IsArrow) {
4747 while (
const auto *RT =
Base->getType()->getAsCanonical<RecordType>()) {
4748 if (!RT->getDecl()->isAnonymousStructOrUnion())
4750 const auto *ME = dyn_cast<MemberExpr>(Base);
4753 Base = ME->getBase();
4754 IsArrow = ME->isArrow();
4757 if (
Base->isImplicitCXXThis()) {
4763 Out << (IsArrow ?
"pt" :
"dt");
4764 mangleExpression(Base);
4769void CXXNameMangler::mangleMemberExpr(
const Expr *base,
bool isArrow,
4770 NestedNameSpecifier Qualifier,
4771 NamedDecl *firstQualifierLookup,
4772 DeclarationName member,
4773 const TemplateArgumentLoc *TemplateArgs,
4774 unsigned NumTemplateArgs,
4779 mangleMemberExprBase(base, isArrow);
4780 mangleUnresolvedName(Qualifier, member, TemplateArgs, NumTemplateArgs, arity);
4793 if (callee == fn)
return false;
4797 if (!lookup)
return false;
4814void CXXNameMangler::mangleCastExpression(
const Expr *E, StringRef CastEncoding) {
4816 Out << CastEncoding;
4821void CXXNameMangler::mangleInitListElements(
const InitListExpr *InitList) {
4823 InitList = Syntactic;
4824 for (
unsigned i = 0, e = InitList->
getNumInits(); i != e; ++i)
4825 mangleExpression(InitList->
getInit(i));
4828void CXXNameMangler::mangleRequirement(SourceLocation RequiresExprLoc,
4829 const concepts::Requirement *Req) {
4830 using concepts::Requirement;
4835 auto HandleSubstitutionFailure =
4836 [&](SourceLocation Loc) {
4837 DiagnosticsEngine &Diags = Context.getDiags();
4838 Diags.
Report(Loc, diag::err_unsupported_itanium_mangling)
4839 << UnsupportedItaniumManglingKind::
4840 RequiresExprWithSubstitutionFailure;
4845 case Requirement::RK_Type: {
4847 if (TR->isSubstitutionFailure())
4848 return HandleSubstitutionFailure(
4849 TR->getSubstitutionDiagnostic()->DiagLoc);
4852 mangleType(TR->getType()->getType());
4856 case Requirement::RK_Simple:
4857 case Requirement::RK_Compound: {
4859 if (ER->isExprSubstitutionFailure())
4860 return HandleSubstitutionFailure(
4861 ER->getExprSubstitutionDiagnostic()->DiagLoc);
4864 mangleExpression(ER->getExpr());
4866 if (ER->hasNoexceptRequirement())
4869 if (!ER->getReturnTypeRequirement().isEmpty()) {
4870 if (ER->getReturnTypeRequirement().isSubstitutionFailure())
4871 return HandleSubstitutionFailure(ER->getReturnTypeRequirement()
4872 .getSubstitutionDiagnostic()
4876 mangleTypeConstraint(ER->getReturnTypeRequirement().getTypeConstraint());
4881 case Requirement::RK_Nested:
4883 if (NR->hasInvalidConstraint()) {
4886 return HandleSubstitutionFailure(RequiresExprLoc);
4890 mangleExpression(NR->getConstraintExpr());
4895void CXXNameMangler::mangleExpression(
const Expr *E,
unsigned Arity,
4896 bool AsTemplateArg) {
4929 QualType ImplicitlyConvertedToType;
4933 bool IsPrimaryExpr =
true;
4934 auto NotPrimaryExpr = [&] {
4935 if (AsTemplateArg && IsPrimaryExpr)
4937 IsPrimaryExpr =
false;
4940 auto MangleDeclRefExpr = [&](
const NamedDecl *D) {
4941 switch (D->getKind()) {
4954 case Decl::EnumConstant: {
4961 case Decl::NonTypeTemplateParm:
4974 case Expr::NoStmtClass:
4975#define ABSTRACT_STMT(Type)
4976#define EXPR(Type, Base)
4977#define STMT(Type, Base) \
4978 case Expr::Type##Class:
4979#include "clang/AST/StmtNodes.inc"
4984 case Expr::AddrLabelExprClass:
4985 case Expr::DesignatedInitUpdateExprClass:
4986 case Expr::ImplicitValueInitExprClass:
4987 case Expr::ArrayInitLoopExprClass:
4988 case Expr::ArrayInitIndexExprClass:
4989 case Expr::NoInitExprClass:
4990 case Expr::ParenListExprClass:
4991 case Expr::MSPropertyRefExprClass:
4992 case Expr::MSPropertySubscriptExprClass:
4993 case Expr::RecoveryExprClass:
4994 case Expr::ArraySectionExprClass:
4995 case Expr::OMPArrayShapingExprClass:
4996 case Expr::OMPIteratorExprClass:
4997 case Expr::CXXInheritedCtorInitExprClass:
4998 case Expr::CXXParenListInitExprClass:
4999 llvm_unreachable(
"unexpected statement kind");
5001 case Expr::ConstantExprClass:
5005 case Expr::CXXReflectExprClass: {
5007 assert(
false &&
"unimplemented");
5012 case Expr::BlockExprClass:
5013 case Expr::ChooseExprClass:
5014 case Expr::CompoundLiteralExprClass:
5015 case Expr::ExtVectorElementExprClass:
5016 case Expr::MatrixElementExprClass:
5017 case Expr::GenericSelectionExprClass:
5018 case Expr::ObjCEncodeExprClass:
5019 case Expr::ObjCIsaExprClass:
5020 case Expr::ObjCIvarRefExprClass:
5021 case Expr::ObjCMessageExprClass:
5022 case Expr::ObjCPropertyRefExprClass:
5023 case Expr::ObjCProtocolExprClass:
5024 case Expr::ObjCSelectorExprClass:
5025 case Expr::ObjCStringLiteralClass:
5026 case Expr::ObjCBoxedExprClass:
5027 case Expr::ObjCArrayLiteralClass:
5028 case Expr::ObjCDictionaryLiteralClass:
5029 case Expr::ObjCSubscriptRefExprClass:
5030 case Expr::ObjCIndirectCopyRestoreExprClass:
5031 case Expr::ObjCAvailabilityCheckExprClass:
5032 case Expr::OffsetOfExprClass:
5033 case Expr::PredefinedExprClass:
5034 case Expr::ShuffleVectorExprClass:
5035 case Expr::ConvertVectorExprClass:
5036 case Expr::StmtExprClass:
5037 case Expr::ArrayTypeTraitExprClass:
5038 case Expr::ExpressionTraitExprClass:
5039 case Expr::VAArgExprClass:
5040 case Expr::CUDAKernelCallExprClass:
5041 case Expr::AsTypeExprClass:
5042 case Expr::PseudoObjectExprClass:
5043 case Expr::AtomicExprClass:
5044 case Expr::SourceLocExprClass:
5045 case Expr::EmbedExprClass:
5046 case Expr::BuiltinBitCastExprClass: {
5050 DiagnosticsEngine &Diags = Context.getDiags();
5058 case Expr::CXXUuidofExprClass: {
5063 if (!isCompatibleWith(LangOptions::ClangABI::Ver11)) {
5064 Out <<
"u8__uuidof";
5073 Out <<
"u8__uuidoft";
5077 Out <<
"u8__uuidofz";
5078 mangleExpression(UuidExp);
5085 case Expr::BinaryConditionalOperatorClass: {
5087 DiagnosticsEngine &Diags = Context.getDiags();
5089 << UnsupportedItaniumManglingKind::TernaryWithOmittedMiddleOperand
5095 case Expr::OpaqueValueExprClass:
5096 llvm_unreachable(
"cannot mangle opaque value; mangling wrong thing?");
5098 case Expr::InitListExprClass: {
5106 case Expr::DesignatedInitExprClass: {
5109 for (
const auto &Designator : DIE->designators()) {
5110 if (Designator.isFieldDesignator()) {
5112 mangleSourceName(Designator.getFieldName());
5113 }
else if (Designator.isArrayDesignator()) {
5115 mangleExpression(DIE->getArrayIndex(Designator));
5117 assert(Designator.isArrayRangeDesignator() &&
5118 "unknown designator kind");
5120 mangleExpression(DIE->getArrayRangeStart(Designator));
5121 mangleExpression(DIE->getArrayRangeEnd(Designator));
5124 mangleExpression(DIE->getInit());
5128 case Expr::CXXDefaultArgExprClass:
5132 case Expr::CXXDefaultInitExprClass:
5136 case Expr::CXXStdInitializerListExprClass:
5140 case Expr::SubstNonTypeTemplateParmExprClass: {
5144 if (
auto *CE = dyn_cast<ConstantExpr>(SNTTPE->getReplacement())) {
5146 assert(CE->hasAPValueResult() &&
"expected the NTTP to have an APValue");
5147 mangleValueInTemplateArg(SNTTPE->getParameterType(),
5148 CE->getAPValueResult(),
false,
5158 case Expr::UserDefinedLiteralClass:
5161 case Expr::CXXMemberCallExprClass:
5162 case Expr::CallExprClass: {
5184 CallArity = UnknownArity;
5186 mangleExpression(CE->
getCallee(), CallArity);
5188 mangleExpression(Arg);
5193 case Expr::CXXNewExprClass: {
5196 if (
New->isGlobalNew())
Out <<
"gs";
5197 Out << (
New->isArray() ?
"na" :
"nw");
5199 E =
New->placement_arg_end(); I != E; ++I)
5200 mangleExpression(*I);
5202 mangleType(
New->getAllocatedType());
5203 if (
New->hasInitializer()) {
5204 if (
New->getInitializationStyle() == CXXNewInitializationStyle::Braces)
5208 const Expr *
Init =
New->getInitializer();
5209 if (
const CXXConstructExpr *CCE = dyn_cast<CXXConstructExpr>(
Init)) {
5214 mangleExpression(*I);
5215 }
else if (
const ParenListExpr *PLE = dyn_cast<ParenListExpr>(
Init)) {
5216 for (
unsigned i = 0, e = PLE->getNumExprs(); i != e; ++i)
5217 mangleExpression(PLE->getExpr(i));
5218 }
else if (
New->getInitializationStyle() ==
5219 CXXNewInitializationStyle::Braces &&
5224 mangleExpression(
Init);
5230 case Expr::CXXPseudoDestructorExprClass: {
5233 if (
const Expr *Base = PDE->getBase())
5234 mangleMemberExprBase(Base, PDE->isArrow());
5235 NestedNameSpecifier
Qualifier = PDE->getQualifier();
5236 if (TypeSourceInfo *ScopeInfo = PDE->getScopeTypeInfo()) {
5238 mangleUnresolvedPrefix(Qualifier,
5240 mangleUnresolvedTypeOrSimpleId(ScopeInfo->getType());
5244 if (!mangleUnresolvedTypeOrSimpleId(ScopeInfo->getType()))
5247 }
else if (Qualifier) {
5248 mangleUnresolvedPrefix(Qualifier);
5252 QualType DestroyedType = PDE->getDestroyedType();
5253 mangleUnresolvedTypeOrSimpleId(DestroyedType);
5257 case Expr::MemberExprClass: {
5268 case Expr::UnresolvedMemberExprClass: {
5279 case Expr::CXXDependentScopeMemberExprClass: {
5281 const CXXDependentScopeMemberExpr *ME
5292 case Expr::UnresolvedLookupExprClass: {
5301 case Expr::CXXUnresolvedConstructExprClass: {
5307 assert(N == 1 &&
"unexpected form for list initialization");
5311 mangleInitListElements(IL);
5318 if (N != 1)
Out <<
'_';
5319 for (
unsigned I = 0; I != N; ++I) mangleExpression(CE->
getArg(I));
5320 if (N != 1)
Out <<
'E';
5324 case Expr::CXXConstructExprClass: {
5331 "implicit CXXConstructExpr must have one argument");
5338 mangleExpression(E);
5343 case Expr::CXXTemporaryObjectExprClass: {
5354 if (!List && N != 1)
5356 if (CE->isStdInitListInitialization()) {
5363 mangleInitListElements(ILE);
5366 mangleExpression(E);
5373 case Expr::CXXScalarValueInitExprClass:
5380 case Expr::CXXNoexceptExprClass:
5386 case Expr::UnaryExprOrTypeTraitExprClass: {
5403 QualType T = (ImplicitlyConvertedToType.
isNull() ||
5405 : ImplicitlyConvertedToType;
5407 mangleIntegerLiteral(T,
V);
5413 auto MangleAlignofSizeofArg = [&] {
5423 auto MangleExtensionBuiltin = [&](
const UnaryExprOrTypeTraitExpr *E,
5424 StringRef Name = {}) {
5427 mangleVendorType(Name);
5438 MangleAlignofSizeofArg();
5440 case UETT_PreferredAlignOf:
5444 if (!isCompatibleWith(LangOptions::ClangABI::Ver11)) {
5445 MangleExtensionBuiltin(SAE,
"__alignof__");
5451 MangleAlignofSizeofArg();
5455 case UETT_VectorElements:
5456 case UETT_OpenMPRequiredSimdAlign:
5458 case UETT_PtrAuthTypeDiscriminator:
5459 case UETT_DataSizeOf: {
5460 DiagnosticsEngine &Diags = Context.getDiags();
5469 case Expr::TypeTraitExprClass: {
5474 mangleVendorType(Spelling);
5475 for (TypeSourceInfo *TSI : TTE->
getArgs()) {
5476 mangleType(TSI->getType());
5482 case Expr::CXXThrowExprClass: {
5496 case Expr::CXXTypeidExprClass: {
5511 case Expr::CXXDeleteExprClass: {
5522 case Expr::UnaryOperatorClass: {
5531 case Expr::ArraySubscriptExprClass: {
5538 mangleExpression(AE->
getLHS());
5539 mangleExpression(AE->
getRHS());
5543 case Expr::MatrixSingleSubscriptExprClass: {
5547 mangleExpression(ME->
getBase());
5552 case Expr::MatrixSubscriptExprClass: {
5556 mangleExpression(ME->
getBase());
5562 case Expr::CompoundAssignOperatorClass:
5563 case Expr::BinaryOperatorClass: {
5571 mangleExpression(BO->
getLHS());
5572 mangleExpression(BO->
getRHS());
5576 case Expr::CXXRewrittenBinaryOperatorClass: {
5579 CXXRewrittenBinaryOperator::DecomposedForm Decomposed =
5583 mangleExpression(Decomposed.
LHS);
5584 mangleExpression(Decomposed.
RHS);
5588 case Expr::ConditionalOperatorClass: {
5591 mangleOperatorName(OO_Conditional, 3);
5592 mangleExpression(CO->
getCond());
5593 mangleExpression(CO->
getLHS(), Arity);
5594 mangleExpression(CO->
getRHS(), Arity);
5598 case Expr::ImplicitCastExprClass: {
5599 ImplicitlyConvertedToType = E->
getType();
5604 case Expr::ObjCBridgedCastExprClass: {
5610 mangleCastExpression(E,
"cv");
5614 case Expr::CStyleCastExprClass:
5616 mangleCastExpression(E,
"cv");
5619 case Expr::CXXFunctionalCastExprClass: {
5623 if (
auto *CCE = dyn_cast<CXXConstructExpr>(Sub))
5624 if (CCE->getParenOrBraceRange().isInvalid())
5625 Sub = CCE->getArg(0)->IgnoreImplicit();
5626 if (
auto *StdInitList = dyn_cast<CXXStdInitializerListExpr>(Sub))
5627 Sub = StdInitList->getSubExpr()->IgnoreImplicit();
5628 if (
auto *IL = dyn_cast<InitListExpr>(Sub)) {
5631 mangleInitListElements(IL);
5634 mangleCastExpression(E,
"cv");
5639 case Expr::CXXStaticCastExprClass:
5641 mangleCastExpression(E,
"sc");
5643 case Expr::CXXDynamicCastExprClass:
5645 mangleCastExpression(E,
"dc");
5647 case Expr::CXXReinterpretCastExprClass:
5649 mangleCastExpression(E,
"rc");
5651 case Expr::CXXConstCastExprClass:
5653 mangleCastExpression(E,
"cc");
5655 case Expr::CXXAddrspaceCastExprClass:
5657 mangleCastExpression(E,
"ac");
5660 case Expr::CXXOperatorCallExprClass: {
5669 for (
unsigned i = 0; i != NumArgs; ++i)
5670 mangleExpression(CE->
getArg(i));
5674 case Expr::ParenExprClass:
5678 case Expr::ConceptSpecializationExprClass: {
5680 if (isCompatibleWith(LangOptions::ClangABI::Ver17)) {
5685 mangleTemplateName(CSE->getNamedConcept(), CSE->getTemplateArguments());
5691 mangleUnresolvedName(
5692 CSE->getNestedNameSpecifierLoc().getNestedNameSpecifier(),
5693 CSE->getConceptNameInfo().getName(),
5694 CSE->getTemplateArgsAsWritten()->getTemplateArgs(),
5695 CSE->getTemplateArgsAsWritten()->getNumTemplateArgs());
5699 case Expr::RequiresExprClass: {
5705 if (RE->getLParenLoc().isValid()) {
5707 FunctionTypeDepthState saved = FunctionTypeDepth.push();
5708 if (RE->getLocalParameters().empty()) {
5711 for (ParmVarDecl *Param : RE->getLocalParameters()) {
5719 FunctionTypeDepth.enterFunctionDeclSuffix();
5720 for (
const concepts::Requirement *Req : RE->getRequirements())
5721 mangleRequirement(RE->getExprLoc(), Req);
5722 FunctionTypeDepth.pop(saved);
5726 for (
const concepts::Requirement *Req : RE->getRequirements())
5727 mangleRequirement(RE->getExprLoc(), Req);
5733 case Expr::DeclRefExprClass:
5738 case Expr::SubstNonTypeTemplateParmPackExprClass:
5744 Out <<
"_SUBSTPACK_";
5747 case Expr::FunctionParmPackExprClass: {
5751 Out <<
"v110_SUBSTPACK";
5756 case Expr::DependentScopeDeclRefExprClass: {
5765 case Expr::CXXBindTemporaryExprClass:
5769 case Expr::ExprWithCleanupsClass:
5773 case Expr::FloatingLiteralClass: {
5780 case Expr::FixedPointLiteralClass:
5782 mangleFixedPointLiteral();
5785 case Expr::CharacterLiteralClass:
5789 Out << cast<CharacterLiteral>(E)->getValue();
5794 case Expr::ObjCBoolLiteralExprClass:
5797 Out << (cast<ObjCBoolLiteralExpr>(E)->getValue() ?
'1' :
'0');
5801 case Expr::CXXBoolLiteralExprClass:
5804 Out << (cast<CXXBoolLiteralExpr>(E)->getValue() ?
'1' :
'0');
5808 case Expr::IntegerLiteralClass: {
5812 Value.setIsSigned(
true);
5817 case Expr::ImaginaryLiteralClass: {
5824 if (
const FloatingLiteral *Imag =
5825 dyn_cast<FloatingLiteral>(IE->
getSubExpr())) {
5827 mangleFloat(llvm::APFloat(Imag->getValue().getSemantics()));
5829 mangleFloat(Imag->getValue());
5834 Value.setIsSigned(
true);
5835 mangleNumber(
Value);
5841 case Expr::StringLiteralClass: {
5851 case Expr::GNUNullExprClass:
5854 mangleIntegerLiteral(E->
getType(), llvm::APSInt(32));
5857 case Expr::CXXNullPtrLiteralExprClass: {
5863 case Expr::LambdaExprClass: {
5874 case Expr::PackExpansionExprClass:
5880 case Expr::SizeOfPackExprClass: {
5883 if (SPE->isPartiallySubstituted()) {
5885 for (
const auto &A : SPE->getPartialArguments())
5886 mangleTemplateArg(A,
false);
5892 mangleReferenceToPack(SPE->getPack());
5896 case Expr::MaterializeTemporaryExprClass:
5900 case Expr::CXXFoldExprClass: {
5903 if (FE->isLeftFold())
5904 Out << (FE->getInit() ?
"fL" :
"fl");
5906 Out << (FE->getInit() ?
"fR" :
"fr");
5908 if (FE->getOperator() == BO_PtrMemD)
5916 mangleExpression(FE->getLHS());
5918 mangleExpression(FE->getRHS());
5922 case Expr::PackIndexingExprClass: {
5926 mangleReferenceToPack(PE->getPackDecl());
5927 mangleExpression(PE->getIndexExpr());
5931 case Expr::CXXThisExprClass:
5936 case Expr::CoawaitExprClass:
5939 Out <<
"v18co_await";
5943 case Expr::DependentCoawaitExprClass:
5946 Out <<
"v18co_await";
5950 case Expr::CoyieldExprClass:
5953 Out <<
"v18co_yield";
5956 case Expr::SYCLUniqueStableNameExprClass: {
5960 Out <<
"u33__builtin_sycl_unique_stable_name";
5961 mangleType(USN->getTypeSourceInfo()->getType());
5966 case Expr::HLSLOutArgExprClass:
5968 "cannot mangle hlsl temporary value; mangling wrong thing?");
5969 case Expr::OpenACCAsteriskSizeExprClass: {
5971 DiagnosticsEngine &Diags = Context.getDiags();
5972 Diags.
Report(diag::err_unsupported_itanium_mangling)
5973 << UnsupportedItaniumManglingKind::OpenACCAsteriskSizeExpr;
5978 if (AsTemplateArg && !IsPrimaryExpr)
6010void CXXNameMangler::mangleFunctionParam(
const ParmVarDecl *parm) {
6015 if (
unsigned nestingDepth = FunctionTypeDepth.getNestingDepth(parmDepth);
6016 nestingDepth == 0) {
6019 Out <<
"fL" << (nestingDepth - 1) <<
'p';
6027 &&
"parameter's type is still an array type?");
6029 if (
const DependentAddressSpaceType *DAST =
6030 dyn_cast<DependentAddressSpaceType>(parm->
getType())) {
6037 if (parmIndex != 0) {
6038 Out << (parmIndex - 1);
6043void CXXNameMangler::mangleCXXCtorType(
CXXCtorType T,
6044 const CXXRecordDecl *InheritedFrom) {
6071 llvm_unreachable(
"closure constructors don't exist for the Itanium ABI!");
6074 mangleName(InheritedFrom);
6077void CXXNameMangler::mangleCXXDtorType(
CXXDtorType T) {
6102 llvm_unreachable(
"Itanium ABI does not use vector deleting dtors");
6106void CXXNameMangler::mangleReferenceToPack(
const NamedDecl *Pack) {
6107 if (
const auto *TTP = dyn_cast<TemplateTypeParmDecl>(Pack))
6108 mangleTemplateParameter(TTP->getDepth(), TTP->getIndex());
6109 else if (
const auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Pack))
6110 mangleTemplateParameter(NTTP->getDepth(), NTTP->getIndex());
6111 else if (
const auto *TempTP = dyn_cast<TemplateTemplateParmDecl>(Pack))
6112 mangleTemplateParameter(TempTP->getDepth(), TempTP->getIndex());
6146 if (
auto *FTD = dyn_cast_or_null<FunctionTemplateDecl>(
ResolvedTemplate)) {
6147 auto *RD = dyn_cast<CXXRecordDecl>(FTD->getDeclContext());
6148 if (!RD || !RD->isGenericLambda())
6164 if (
auto *TTP = dyn_cast<TemplateTypeParmDecl>(Param))
6165 return TTP->hasTypeConstraint();
6182 if (
auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Param))
6183 return NTTP->getType()->isInstantiationDependentType() ||
6184 NTTP->getType()->getContainedDeducedType();
6191 "A DeducedTemplateName shouldn't escape partial ordering");
6202 auto MangleTemplateParamListToString =
6204 unsigned DepthOffset) {
6205 llvm::raw_svector_ostream Stream(Buffer);
6206 CXXNameMangler(
Mangler.Context, Stream,
6207 WithTemplateDepthOffset{DepthOffset})
6208 .mangleTemplateParameterList(Params);
6211 MangleTemplateParamListToString(ParamTemplateHead,
6212 TTP->getTemplateParameters(), 0);
6216 MangleTemplateParamListToString(ArgTemplateHead,
6218 TTP->getTemplateParameters()->
getDepth());
6219 return ParamTemplateHead != ArgTemplateHead;
6229 return {
true,
nullptr};
6234 assert(ParamIdx < ResolvedTemplate->getTemplateParameters()->size() &&
6235 "no parameter for argument");
6256 return {
true,
nullptr};
6271 auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Param);
6272 bool NeedExactType = NTTP && NTTP->getType()->getContainedDeducedType();
6273 return {NeedExactType,
nullptr};
6285void CXXNameMangler::mangleTemplateArgs(
TemplateName TN,
6287 unsigned NumTemplateArgs) {
6290 TemplateArgManglingInfo Info(*
this, TN);
6291 for (
unsigned i = 0; i != NumTemplateArgs; ++i) {
6292 mangleTemplateArg(Info, i, TemplateArgs[i].
getArgument());
6294 mangleRequiresClause(Info.getTrailingRequiresClauseToMangle());
6298void CXXNameMangler::mangleTemplateArgs(
TemplateName TN,
6299 const TemplateArgumentList &AL) {
6302 TemplateArgManglingInfo Info(*
this, TN);
6303 for (
unsigned i = 0, e = AL.
size(); i != e; ++i) {
6304 mangleTemplateArg(Info, i, AL[i]);
6306 mangleRequiresClause(Info.getTrailingRequiresClauseToMangle());
6310void CXXNameMangler::mangleTemplateArgs(
TemplateName TN,
6311 ArrayRef<TemplateArgument> Args) {
6314 TemplateArgManglingInfo Info(*
this, TN);
6315 for (
unsigned i = 0; i != Args.size(); ++i) {
6316 mangleTemplateArg(Info, i, Args[i]);
6318 mangleRequiresClause(Info.getTrailingRequiresClauseToMangle());
6322void CXXNameMangler::mangleTemplateArg(TemplateArgManglingInfo &Info,
6323 unsigned Index, TemplateArgument A) {
6324 TemplateArgManglingInfo::Info ArgInfo = Info.getArgInfo(Index, A);
6327 if (ArgInfo.TemplateParameterToMangle &&
6328 !isCompatibleWith(LangOptions::ClangABI::Ver17)) {
6335 mangleTemplateParamDecl(ArgInfo.TemplateParameterToMangle);
6338 mangleTemplateArg(A, ArgInfo.NeedExactType);
6341void CXXNameMangler::mangleTemplateArg(TemplateArgument A,
bool NeedExactType) {
6351 llvm_unreachable(
"Cannot mangle NULL template argument");
6379 mangleValueInTemplateArg(TPO->getType().getUnqualifiedType(),
6380 TPO->getValue(),
true,
6385 ASTContext &Ctx = Context.getASTContext();
6393 !isCompatibleWith(LangOptions::ClangABI::Ver11))
6401 ArrayRef<APValue::LValuePathEntry>(),
6414 true, NeedExactType);
6420 mangleTemplateArg(P, NeedExactType);
6426void CXXNameMangler::mangleTemplateArgExpr(
const Expr *E) {
6427 if (!isCompatibleWith(LangOptions::ClangABI::Ver11)) {
6428 mangleExpression(E, UnknownArity,
true);
6443 if (
const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) {
6444 const ValueDecl *D = DRE->getDecl();
6453 mangleExpression(E);
6466 switch (
V.getKind()) {
6474 assert(RD &&
"unexpected type for record value");
6483 if (!FD->isUnnamedBitField() &&
6493 assert(RD &&
"unexpected type for union value");
6496 if (!FD->isUnnamedBitField())
6506 QualType ElemT(T->getArrayElementTypeNoTypeQual(), 0);
6507 for (
unsigned I = 0, N =
V.getArrayInitializedElts(); I != N; ++I)
6515 for (
unsigned I = 0, N =
V.getVectorLength(); I != N; ++I)
6522 llvm_unreachable(
"Matrix APValues not yet supported");
6528 return V.getFloat().isPosZero();
6531 return !
V.getFixedPoint().getValue();
6534 return V.getComplexFloatReal().isPosZero() &&
6535 V.getComplexFloatImag().isPosZero();
6538 return !
V.getComplexIntReal() && !
V.getComplexIntImag();
6541 return V.isNullPointer();
6544 return !
V.getMemberPointerDecl();
6547 llvm_unreachable(
"Unhandled APValue::ValueKind enum");
6554 T = AT->getElementType();
6556 dyn_cast<FieldDecl>(E.getAsBaseOrMember().getPointer()))
6599 Diags.
Report(UnionLoc, diag::err_unsupported_itanium_mangling)
6600 << UnsupportedItaniumManglingKind::UnnamedUnionNTTP;
6605void CXXNameMangler::mangleValueInTemplateArg(QualType T,
const APValue &
V,
6607 bool NeedExactType) {
6610 T = getASTContext().getUnqualifiedArrayType(T, Quals);
6613 bool IsPrimaryExpr =
true;
6614 auto NotPrimaryExpr = [&] {
6615 if (TopLevel && IsPrimaryExpr)
6617 IsPrimaryExpr =
false;
6621 switch (
V.getKind()) {
6630 llvm_unreachable(
"unexpected value kind in template argument");
6634 assert(RD &&
"unexpected type for record value");
6637 llvm::SmallVector<const FieldDecl *, 16> Fields(RD->
fields());
6640 (Fields.back()->isUnnamedBitField() ||
6642 V.getStructField(Fields.back()->getFieldIndex())))) {
6646 if (Fields.empty()) {
6647 while (!Bases.empty() &&
6649 V.getStructBase(Bases.size() - 1)))
6650 Bases = Bases.drop_back();
6657 for (
unsigned I = 0, N = Bases.size(); I != N; ++I)
6658 mangleValueInTemplateArg(Bases[I].
getType(),
V.getStructBase(I),
false);
6659 for (
unsigned I = 0, N = Fields.size(); I != N; ++I) {
6660 if (Fields[I]->isUnnamedBitField())
6662 mangleValueInTemplateArg(Fields[I]->
getType(),
6663 V.getStructField(Fields[I]->getFieldIndex()),
6672 const FieldDecl *FD =
V.getUnionField();
6690 mangleSourceName(II);
6691 mangleValueInTemplateArg(FD->
getType(),
V.getUnionValue(),
false);
6705 unsigned N =
V.getArraySize();
6707 N =
V.getArrayInitializedElts();
6712 for (
unsigned I = 0; I != N; ++I) {
6713 const APValue &Elem = I <
V.getArrayInitializedElts()
6714 ?
V.getArrayInitializedElt(I)
6715 :
V.getArrayFiller();
6716 mangleValueInTemplateArg(ElemT, Elem,
false);
6723 const VectorType *VT = T->
castAs<VectorType>();
6728 unsigned N =
V.getVectorLength();
6731 for (
unsigned I = 0; I != N; ++I)
6732 mangleValueInTemplateArg(VT->
getElementType(),
V.getVectorElt(I),
false);
6738 llvm_unreachable(
"Matrix template argument mangling not yet supported");
6741 mangleIntegerLiteral(T,
V.getInt());
6745 mangleFloatLiteral(T,
V.getFloat());
6749 mangleFixedPointLiteral();
6753 const ComplexType *CT = T->
castAs<ComplexType>();
6757 if (!
V.getComplexFloatReal().isPosZero() ||
6758 !
V.getComplexFloatImag().isPosZero())
6760 if (!
V.getComplexFloatImag().isPosZero())
6767 const ComplexType *CT = T->
castAs<ComplexType>();
6771 if (
V.getComplexIntReal().getBoolValue() ||
6772 V.getComplexIntImag().getBoolValue())
6774 if (
V.getComplexIntImag().getBoolValue())
6783 "unexpected type for LValue template arg");
6785 if (
V.isNullPointer()) {
6786 mangleNullPointer(T);
6790 APValue::LValueBase B =
V.getLValueBase();
6794 CharUnits Offset =
V.getLValueOffset();
6812 ASTContext &Ctx = Context.getASTContext();
6815 if (!
V.hasLValuePath()) {
6831 bool IsArrayToPointerDecayMangledAsDecl =
false;
6832 if (TopLevel && isCompatibleWith(LangOptions::ClangABI::Ver11)) {
6834 IsArrayToPointerDecayMangledAsDecl =
6835 BType->
isArrayType() &&
V.getLValuePath().size() == 1 &&
6836 V.getLValuePath()[0].getAsArrayIndex() == 0 &&
6840 if ((!
V.getLValuePath().empty() ||
V.isLValueOnePastTheEnd()) &&
6841 !IsArrayToPointerDecayMangledAsDecl) {
6858 if (NeedExactType &&
6860 !isCompatibleWith(LangOptions::ClangABI::Ver11)) {
6873 QualType TypeSoFar = B.
getType();
6874 if (
auto *VD = B.
dyn_cast<
const ValueDecl*>()) {
6878 }
else if (
auto *E = B.
dyn_cast<
const Expr*>()) {
6880 mangleExpression(E);
6881 }
else if (
auto TI = B.
dyn_cast<TypeInfoLValue>()) {
6884 mangleType(QualType(TI.getType(), 0));
6887 llvm_unreachable(
"unexpected lvalue base kind in template argument");
6897 mangleNumber(
V.getLValueOffset().getQuantity());
6904 if (!
V.getLValueOffset().isZero())
6905 mangleNumber(
V.getLValueOffset().getQuantity());
6909 bool OnePastTheEnd =
V.isLValueOnePastTheEnd();
6911 for (APValue::LValuePathEntry E :
V.getLValuePath()) {
6913 if (
auto *CAT = dyn_cast<ConstantArrayType>(AT))
6914 OnePastTheEnd |= CAT->getSize() == E.getAsArrayIndex();
6915 TypeSoFar = AT->getElementType();
6917 const Decl *D = E.getAsBaseOrMember().getPointer();
6918 if (
auto *FD = dyn_cast<FieldDecl>(D)) {
6943 if (!
V.getMemberPointerDecl()) {
6944 mangleNullPointer(T);
6948 ASTContext &Ctx = Context.getASTContext();
6951 if (!
V.getMemberPointerPath().empty()) {
6954 }
else if (NeedExactType &&
6956 T->
castAs<MemberPointerType>()->getPointeeType(),
6957 V.getMemberPointerDecl()->getType()) &&
6958 !isCompatibleWith(LangOptions::ClangABI::Ver11)) {
6963 mangle(
V.getMemberPointerDecl());
6965 if (!
V.getMemberPointerPath().empty()) {
6975 if (TopLevel && !IsPrimaryExpr)
6979void CXXNameMangler::mangleTemplateParameter(
unsigned Depth,
unsigned Index) {
6989 Depth += TemplateDepthOffset;
6991 Out <<
'L' << (Depth - 1) <<
'_';
6997void CXXNameMangler::mangleSeqID(
unsigned SeqID) {
7000 }
else if (SeqID == 1) {
7007 MutableArrayRef<char> BufferRef(Buffer);
7008 MutableArrayRef<char>::reverse_iterator I = BufferRef.rbegin();
7010 for (; SeqID != 0; SeqID /= 36) {
7011 unsigned C = SeqID % 36;
7012 *I++ = (
C < 10 ?
'0' +
C :
'A' +
C - 10);
7015 Out.write(I.base(), I - BufferRef.rbegin());
7020void CXXNameMangler::mangleExistingSubstitution(
TemplateName tname) {
7021 bool result = mangleSubstitution(tname);
7022 assert(result &&
"no existing substitution for template name");
7028bool CXXNameMangler::mangleSubstitution(
const NamedDecl *ND) {
7030 if (mangleStandardSubstitution(ND))
7034 return mangleSubstitution(
reinterpret_cast<uintptr_t>(ND));
7044bool CXXNameMangler::mangleSubstitution(QualType T) {
7047 return mangleSubstitution(RD);
7052 return mangleSubstitution(TypePtr);
7056 if (TemplateDecl *TD =
Template.getAsTemplateDecl())
7057 return mangleSubstitution(TD);
7060 return mangleSubstitution(
7064bool CXXNameMangler::mangleSubstitution(
uintptr_t Ptr) {
7065 llvm::DenseMap<uintptr_t, unsigned>::iterator I = Substitutions.find(Ptr);
7066 if (I == Substitutions.end())
7069 unsigned SeqID = I->second;
7078bool CXXNameMangler::isSpecializedAs(QualType S, llvm::StringRef Name,
7087 const auto *SD = dyn_cast<ClassTemplateSpecializationDecl>(RT->getDecl());
7088 if (!SD || !SD->getIdentifier()->isStr(Name))
7091 if (!isStdNamespace(Context.getEffectiveDeclContext(SD)))
7094 const TemplateArgumentList &TemplateArgs = SD->getTemplateArgs();
7095 if (TemplateArgs.
size() != 1)
7098 if (TemplateArgs[0].getAsType() != A)
7101 if (SD->getSpecializedTemplate()->getOwningModuleForLinkage())
7110bool CXXNameMangler::isStdCharSpecialization(
7111 const ClassTemplateSpecializationDecl *SD, llvm::StringRef Name,
7112 bool HasAllocator) {
7117 if (TemplateArgs.
size() != (HasAllocator ? 3 : 2))
7120 QualType A = TemplateArgs[0].getAsType();
7128 if (!isSpecializedAs(TemplateArgs[1].getAsType(),
"char_traits", A))
7132 !isSpecializedAs(TemplateArgs[2].getAsType(),
"allocator", A))
7141bool CXXNameMangler::mangleStandardSubstitution(
const NamedDecl *ND) {
7143 if (
const NamespaceDecl *NS = dyn_cast<NamespaceDecl>(ND)) {
7151 if (
const ClassTemplateDecl *TD = dyn_cast<ClassTemplateDecl>(ND)) {
7152 if (!isStdNamespace(Context.getEffectiveDeclContext(TD)))
7172 if (
const ClassTemplateSpecializationDecl *SD =
7173 dyn_cast<ClassTemplateSpecializationDecl>(ND)) {
7174 if (!isStdNamespace(Context.getEffectiveDeclContext(SD)))
7183 if (isStdCharSpecialization(SD,
"basic_string",
true)) {
7190 if (isStdCharSpecialization(SD,
"basic_istream",
false)) {
7197 if (isStdCharSpecialization(SD,
"basic_ostream",
false)) {
7204 if (isStdCharSpecialization(SD,
"basic_iostream",
false)) {
7214void CXXNameMangler::addSubstitution(QualType T) {
7217 addSubstitution(RD);
7223 addSubstitution(TypePtr);
7227 if (TemplateDecl *TD =
Template.getAsTemplateDecl())
7228 return addSubstitution(TD);
7234void CXXNameMangler::addSubstitution(
uintptr_t Ptr) {
7235 assert(!Substitutions.count(Ptr) &&
"Substitution already exists!");
7236 Substitutions[Ptr] = SeqID++;
7239void CXXNameMangler::extendSubstitutions(CXXNameMangler*
Other) {
7240 assert(
Other->SeqID >= SeqID &&
"Must be superset of substitutions!");
7241 if (
Other->SeqID > SeqID) {
7242 Substitutions.swap(
Other->Substitutions);
7243 SeqID =
Other->SeqID;
7247CXXNameMangler::AbiTagList
7248CXXNameMangler::makeFunctionReturnTypeTags(
const FunctionDecl *FD) {
7250 if (DisableDerivedAbiTags)
7251 return AbiTagList();
7253 llvm::raw_null_ostream NullOutStream;
7254 CXXNameMangler TrackReturnTypeTags(*
this, NullOutStream);
7255 TrackReturnTypeTags.disableDerivedAbiTags();
7257 const FunctionProtoType *Proto =
7259 FunctionTypeDepthState saved = TrackReturnTypeTags.FunctionTypeDepth.push();
7260 TrackReturnTypeTags.FunctionTypeDepth.enterFunctionDeclSuffix();
7262 TrackReturnTypeTags.FunctionTypeDepth.leaveFunctionDeclSuffix();
7263 TrackReturnTypeTags.FunctionTypeDepth.pop(saved);
7265 return TrackReturnTypeTags.AbiTagsRoot.getSortedUniqueUsedAbiTags();
7268CXXNameMangler::AbiTagList
7269CXXNameMangler::makeVariableTypeTags(
const VarDecl *VD) {
7271 if (DisableDerivedAbiTags)
7272 return AbiTagList();
7274 llvm::raw_null_ostream NullOutStream;
7275 CXXNameMangler TrackVariableType(*
this, NullOutStream);
7276 TrackVariableType.disableDerivedAbiTags();
7278 TrackVariableType.mangleType(VD->
getType());
7280 return TrackVariableType.AbiTagsRoot.getSortedUniqueUsedAbiTags();
7283bool CXXNameMangler::shouldHaveAbiTags(ItaniumMangleContextImpl &
C,
7284 const VarDecl *VD) {
7285 llvm::raw_null_ostream NullOutStream;
7286 CXXNameMangler TrackAbiTags(
C, NullOutStream,
nullptr,
true);
7287 TrackAbiTags.mangle(VD);
7288 return TrackAbiTags.AbiTagsRoot.getUsedAbiTags().size();
7293void ItaniumMangleContextImpl::mangleCXXName(GlobalDecl GD,
7297 "Invalid mangleName() call, argument is not a variable or function!");
7299 PrettyStackTraceDecl CrashInfo(D, SourceLocation(),
7300 getASTContext().getSourceManager(),
7301 "Mangling declaration");
7303 if (
auto *CD = dyn_cast<CXXConstructorDecl>(D)) {
7305 CXXNameMangler Mangler(*
this, Out, CD,
Type);
7306 return Mangler.mangle(GlobalDecl(CD,
Type));
7309 if (
auto *DD = dyn_cast<CXXDestructorDecl>(D)) {
7311 CXXNameMangler Mangler(*
this, Out, DD,
Type);
7312 return Mangler.mangle(GlobalDecl(DD,
Type));
7315 CXXNameMangler Mangler(*
this, Out, D);
7319void ItaniumMangleContextImpl::mangleCXXCtorComdat(
const CXXConstructorDecl *D,
7321 CXXNameMangler Mangler(*
this, Out, D,
Ctor_Comdat);
7325void ItaniumMangleContextImpl::mangleCXXDtorComdat(
const CXXDestructorDecl *D,
7327 CXXNameMangler Mangler(*
this, Out, D,
Dtor_Comdat);
7349 auto &LangOpts = Context.getLangOpts();
7352 Context.baseForVTableAuthentication(ThisRD);
7353 unsigned TypedDiscriminator =
7354 Context.getPointerAuthVTablePointerDiscriminator(ThisRD);
7355 Mangler.mangleVendorQualifier(
"__vtptrauth");
7356 auto &ManglerStream = Mangler.getStream();
7357 ManglerStream <<
"I";
7358 if (
const auto *ExplicitAuth =
7359 PtrauthClassRD->
getAttr<VTablePointerAuthenticationAttr>()) {
7360 ManglerStream <<
"Lj" << ExplicitAuth->getKey();
7362 if (ExplicitAuth->getAddressDiscrimination() ==
7363 VTablePointerAuthenticationAttr::DefaultAddressDiscrimination)
7364 ManglerStream <<
"Lb" << LangOpts.PointerAuthVTPtrAddressDiscrimination;
7366 ManglerStream <<
"Lb"
7367 << (ExplicitAuth->getAddressDiscrimination() ==
7368 VTablePointerAuthenticationAttr::AddressDiscrimination);
7370 switch (ExplicitAuth->getExtraDiscrimination()) {
7371 case VTablePointerAuthenticationAttr::DefaultExtraDiscrimination: {
7372 if (LangOpts.PointerAuthVTPtrTypeDiscrimination)
7373 ManglerStream <<
"Lj" << TypedDiscriminator;
7375 ManglerStream <<
"Lj" << 0;
7378 case VTablePointerAuthenticationAttr::TypeDiscrimination:
7379 ManglerStream <<
"Lj" << TypedDiscriminator;
7381 case VTablePointerAuthenticationAttr::CustomDiscrimination:
7382 ManglerStream <<
"Lj" << ExplicitAuth->getCustomDiscriminationValue();
7384 case VTablePointerAuthenticationAttr::NoExtraDiscrimination:
7385 ManglerStream <<
"Lj" << 0;
7389 ManglerStream <<
"Lj"
7390 << (
unsigned)VTablePointerAuthenticationAttr::DefaultKey;
7391 ManglerStream <<
"Lb" << LangOpts.PointerAuthVTPtrAddressDiscrimination;
7392 if (LangOpts.PointerAuthVTPtrTypeDiscrimination)
7393 ManglerStream <<
"Lj" << TypedDiscriminator;
7395 ManglerStream <<
"Lj" << 0;
7397 ManglerStream <<
"E";
7400void ItaniumMangleContextImpl::mangleThunk(
const CXXMethodDecl *MD,
7401 const ThunkInfo &Thunk,
7402 bool ElideOverrideInfo,
7412 "Use mangleCXXDtor for destructor decls!");
7413 CXXNameMangler Mangler(*
this, Out);
7414 Mangler.getStream() <<
"_ZT";
7416 Mangler.getStream() <<
'c';
7427 Mangler.mangleFunctionEncoding(MD);
7428 if (!ElideOverrideInfo)
7432void ItaniumMangleContextImpl::mangleCXXDtorThunk(
const CXXDestructorDecl *DD,
7434 const ThunkInfo &Thunk,
7435 bool ElideOverrideInfo,
7439 CXXNameMangler Mangler(*
this, Out, DD,
Type);
7440 Mangler.getStream() <<
"_ZT";
7442 auto &ThisAdjustment = Thunk.
This;
7444 Mangler.mangleCallOffset(ThisAdjustment.NonVirtual,
7445 ThisAdjustment.Virtual.Itanium.VCallOffsetOffset);
7447 Mangler.mangleFunctionEncoding(GlobalDecl(DD,
Type));
7448 if (!ElideOverrideInfo)
7453void ItaniumMangleContextImpl::mangleStaticGuardVariable(
const VarDecl *D,
7457 CXXNameMangler Mangler(*
this, Out);
7460 Mangler.getStream() <<
"_ZGV";
7461 Mangler.mangleName(D);
7464void ItaniumMangleContextImpl::mangleDynamicInitializer(
const VarDecl *MD,
7469 Out <<
"__cxx_global_var_init";
7472void ItaniumMangleContextImpl::mangleDynamicAtExitDestructor(
const VarDecl *D,
7475 CXXNameMangler Mangler(*
this, Out);
7476 Mangler.getStream() <<
"__dtor_";
7477 if (shouldMangleDeclName(D))
7480 Mangler.getStream() << D->
getName();
7483void ItaniumMangleContextImpl::mangleDynamicStermFinalizer(
const VarDecl *D,
7487 CXXNameMangler Mangler(*
this, Out);
7488 Mangler.getStream() <<
"__finalize_";
7489 if (shouldMangleDeclName(D))
7492 Mangler.getStream() << D->
getName();
7495void ItaniumMangleContextImpl::mangleSEHFilterExpression(
7496 GlobalDecl EnclosingDecl, raw_ostream &Out) {
7497 CXXNameMangler Mangler(*
this, Out);
7498 Mangler.getStream() <<
"__filt_";
7500 if (shouldMangleDeclName(EnclosingFD))
7501 Mangler.mangle(EnclosingDecl);
7503 Mangler.getStream() << EnclosingFD->getName();
7506void ItaniumMangleContextImpl::mangleSEHFinallyBlock(
7507 GlobalDecl EnclosingDecl, raw_ostream &Out) {
7508 CXXNameMangler Mangler(*
this, Out);
7509 Mangler.getStream() <<
"__fin_";
7511 if (shouldMangleDeclName(EnclosingFD))
7512 Mangler.mangle(EnclosingDecl);
7514 Mangler.getStream() << EnclosingFD->getName();
7517void ItaniumMangleContextImpl::mangleItaniumThreadLocalInit(
const VarDecl *D,
7520 CXXNameMangler Mangler(*
this, Out);
7521 Mangler.getStream() <<
"_ZTH";
7522 Mangler.mangleName(D);
7526ItaniumMangleContextImpl::mangleItaniumThreadLocalWrapper(
const VarDecl *D,
7529 CXXNameMangler Mangler(*
this, Out);
7530 Mangler.getStream() <<
"_ZTW";
7531 Mangler.mangleName(D);
7534void ItaniumMangleContextImpl::mangleReferenceTemporary(
const VarDecl *D,
7535 unsigned ManglingNumber,
7539 CXXNameMangler Mangler(*
this, Out);
7540 Mangler.getStream() <<
"_ZGR";
7541 Mangler.mangleName(D);
7542 assert(ManglingNumber > 0 &&
"Reference temporary mangling number is zero!");
7543 Mangler.mangleSeqID(ManglingNumber - 1);
7546void ItaniumMangleContextImpl::mangleCXXVTable(
const CXXRecordDecl *RD,
7549 CXXNameMangler Mangler(*
this, Out);
7550 Mangler.getStream() <<
"_ZTV";
7551 Mangler.mangleCXXRecordDecl(RD);
7554void ItaniumMangleContextImpl::mangleCXXVTT(
const CXXRecordDecl *RD,
7557 CXXNameMangler Mangler(*
this, Out);
7558 Mangler.getStream() <<
"_ZTT";
7559 Mangler.mangleCXXRecordDecl(RD);
7562void ItaniumMangleContextImpl::mangleCXXCtorVTable(
const CXXRecordDecl *RD,
7564 const CXXRecordDecl *
Type,
7567 CXXNameMangler Mangler(*
this, Out);
7568 Mangler.getStream() <<
"_ZTC";
7571 bool SuppressSubstitution = getASTContext().getLangOpts().isCompatibleWith(
7572 LangOptions::ClangABI::Ver19);
7573 Mangler.mangleCXXRecordDecl(RD, SuppressSubstitution);
7574 Mangler.getStream() << Offset;
7575 Mangler.getStream() <<
'_';
7576 Mangler.mangleCXXRecordDecl(
Type);
7579void ItaniumMangleContextImpl::mangleCXXRTTI(QualType Ty, raw_ostream &Out) {
7581 assert(!Ty.
hasQualifiers() &&
"RTTI info cannot have top-level qualifiers");
7582 CXXNameMangler Mangler(*
this, Out);
7583 Mangler.getStream() <<
"_ZTI";
7584 Mangler.mangleType(Ty);
7587void ItaniumMangleContextImpl::mangleCXXRTTIName(
7588 QualType Ty, raw_ostream &Out,
bool NormalizeIntegers =
false) {
7590 CXXNameMangler Mangler(*
this, Out, NormalizeIntegers);
7591 Mangler.getStream() <<
"_ZTS";
7592 Mangler.mangleType(Ty);
7595void ItaniumMangleContextImpl::mangleCanonicalTypeName(
7596 QualType Ty, raw_ostream &Out,
bool NormalizeIntegers =
false) {
7597 mangleCXXRTTIName(Ty, Out, NormalizeIntegers);
7600void ItaniumMangleContextImpl::mangleStringLiteral(
const StringLiteral *, raw_ostream &) {
7601 llvm_unreachable(
"Can't mangle string literals");
7604void ItaniumMangleContextImpl::mangleLambdaSig(
const CXXRecordDecl *Lambda,
7606 CXXNameMangler Mangler(*
this, Out);
7607 Mangler.mangleLambdaSig(Lambda);
7610void ItaniumMangleContextImpl::mangleModuleInitializer(
const Module *M,
7613 CXXNameMangler Mangler(*
this, Out);
7614 Mangler.getStream() <<
"_ZGI";
7618 auto Partition = M->
Name.find(
':');
7619 Mangler.mangleModuleNamePrefix(
7620 StringRef(&M->
Name[Partition + 1], M->
Name.size() - Partition - 1),
7628 return new ItaniumMangleContextImpl(
7631 return std::nullopt;
7640 return new ItaniumMangleContextImpl(Context, Diags, DiscriminatorOverride,
Enums/classes describing ABI related information about constructors, destructors and thunks.
Defines the clang::ASTContext interface.
static bool isUniqueInternalLinkageDecl(GlobalDecl GD, CodeGenModule &CGM)
@ LLVM_MARK_AS_BITMASK_ENUM
static Decl::Kind getKind(const Decl *D)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
This file defines OpenMP nodes for declarative directives.
Defines the C++ template declaration subclasses.
Defines the clang::Expr interface and subclasses for C++ expressions.
Defines Expressions and AST nodes for C++2a concepts.
static bool isTypeSubstitutable(Qualifiers Quals, const Type *Ty, ASTContext &Ctx)
static IdentifierInfo * getUnionInitName(SourceLocation UnionLoc, DiagnosticsEngine &Diags, const FieldDecl *FD)
static bool hasMangledSubstitutionQualifiers(QualType T)
Determine whether the given type has any qualifiers that are relevant for substitutions.
#define CC_VLS_CASE(ABI_VLEN)
static GlobalDecl getParentOfLocalEntity(const DeclContext *DC)
@ ArmAgnosticSMEZAStateBit
@ ArmStreamingCompatibleBit
static AAPCSBitmaskSME encodeAAPCSZAState(unsigned SMEAttrs)
static StringRef mangleAArch64VectorBase(const BuiltinType *EltType)
static const CXXRecordDecl * getLambdaForInitCapture(const VarDecl *VD)
Retrieve the lambda associated with an init-capture variable.
static void mangleOverrideDiscrimination(CXXNameMangler &Mangler, ASTContext &Context, const ThunkInfo &Thunk)
Mangles the pointer authentication override attribute for classes that have explicit overrides for th...
static bool isZeroInitialized(QualType T, const APValue &V)
Determine whether a given value is equivalent to zero-initialization for the purpose of discarding a ...
static const GlobalDecl isTemplate(GlobalDecl GD, const TemplateArgumentList *&TemplateArgs)
static bool isParenthesizedADLCallee(const CallExpr *call)
Look at the callee of the given call expression and determine if it's a parenthesized id-expression w...
static TemplateName asTemplateName(GlobalDecl GD)
static QualType getLValueType(ASTContext &Ctx, const APValue &LV)
llvm::MachO::Target Target
llvm::MachO::Record Record
Defines the clang::Module class, which describes a module in the source code.
static StringRef getTriple(const Command &Job)
static StringRef getIdentifier(const Token &Tok)
Enums/classes describing THUNK related information about constructors, destructors and thunks.
Defines the clang::TypeLoc interface and its subclasses.
static const TemplateArgument & getArgument(const TemplateArgument &A)
A non-discriminated union of a base, field, or array index.
static LValuePathEntry ArrayIndex(uint64_t Index)
APValue - This class implements a discriminated union of [uninitialized] [APSInt] [APFloat],...
const LValueBase getLValueBase() const
ArrayRef< LValuePathEntry > getLValuePath() const
@ Indeterminate
This object has an indeterminate value (C++ [basic.indet]).
@ None
There is no such object (it's outside its lifetime).
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
TemplateArgument getCanonicalTemplateArgument(const TemplateArgument &Arg) const
Retrieve the "canonical" template argument.
CharUnits getMemberPointerPathAdjustment(const APValue &MP) const
Find the 'this' offset for the member path in a pointer-to-member APValue.
TemplateName getCanonicalTemplateName(TemplateName Name, bool IgnoreDeduced=false) const
Retrieves the "canonical" template name that refers to a given template.
const LangOptions & getLangOpts() const
QualType getDecayedType(QualType T) const
Return the uniqued reference to the decayed version of the given type.
QualType getPointerDiffType() const
Return the unique type for "ptrdiff_t" (C99 7.17) defined in <stddef.h>.
QualType getSignatureParameterType(QualType T) const
Retrieve the parameter type as adjusted for use in the signature of a function, decaying array and fu...
bool addressSpaceMapManglingFor(LangAS AS) const
const ArrayType * getAsArrayType(QualType T) const
Type Query functions.
static bool hasSameType(QualType T1, QualType T2)
Determine whether the given types T1 and T2 are equivalent.
bool hasSimilarType(QualType T1, QualType T2) const
Determine if two types are similar, according to the C++ rules.
CanQualType getCanonicalTagType(const TagDecl *TD) const
unsigned getTargetAddressSpace(LangAS AS) const
Expr * getLHS()
An array access can be written A[4] or 4[A] (both are equivalent).
Represents an array type, per C99 6.7.5.2 - Array Declarators.
QualType getElementType() const
QualType getValueType() const
Gets the type contained by this atomic type, i.e.
static OverloadedOperatorKind getOverloadedOperator(Opcode Opc)
Retrieve the overloaded operator kind that corresponds to the given binary opcode.
unsigned getNumBits() const
QualType getPointeeType() const
This class is used for builtin types like 'int'.
bool isSignedInteger() const
Represents a base class of a C++ class.
ConstExprIterator const_arg_iterator
InheritedConstructor getInheritedConstructor() const
Get the constructor that this inheriting constructor is based on.
bool isGlobalDelete() const
bool isArrow() const
Determine whether this member expression used the '->' operator; otherwise, it used the '.
NestedNameSpecifier getQualifier() const
Retrieve the nested-name-specifier that qualifies the member name.
unsigned getNumTemplateArgs() const
Retrieve the number of template arguments provided as part of this template-id.
const TemplateArgumentLoc * getTemplateArgs() const
Retrieve the template arguments provided as part of this template-id.
DeclarationName getMember() const
Retrieve the name of the member that this expression refers to.
NamedDecl * getFirstQualifierFoundInScope() const
Retrieve the first part of the nested-name-specifier that was found in the scope of the member access...
Expr * getBase() const
Retrieve the base object of this member expressions, e.g., the x in x.m.
bool isImplicitAccess() const
True if this is an implicit access, i.e.
ConstExprIterator const_arg_iterator
OverloadedOperatorKind getOperator() const
Returns the kind of overloaded operator that this expression refers to.
Represents a C++ struct/union/class.
Decl * getLambdaContextDecl() const
Retrieve the declaration that provides additional context for a lambda, when the normal declaration c...
TemplateParameterList * getGenericLambdaTemplateParameterList() const
Retrieve the generic lambda's template parameter list.
base_class_iterator bases_end()
bool isLambda() const
Determine whether this class describes a lambda function object.
unsigned getLambdaManglingNumber() const
If this is the closure type of a lambda expression, retrieve the number to be used for name mangling ...
base_class_iterator bases_begin()
TypeSourceInfo * getLambdaTypeInfo() const
ArrayRef< NamedDecl * > getLambdaExplicitTemplateParameters() const
Retrieve the lambda template parameters that were specified explicitly.
CXXMethodDecl * getLambdaStaticInvoker() const
Retrieve the lambda static invoker, the address of which is returned by the conversion operator,...
const Expr * getSubExpr() const
bool isTypeOperand() const
QualType getTypeOperand(const ASTContext &Context) const
Retrieves the type operand of this typeid() expression after various required adjustments (removing r...
Expr * getExprOperand() const
bool isListInitialization() const
Determine whether this expression models list-initialization.
Expr * getArg(unsigned I)
unsigned getNumArgs() const
Retrieve the number of arguments.
Expr * getExprOperand() const
QualType getTypeOperand(ASTContext &Context) const
Retrieves the type operand of this __uuidof() expression after various required adjustments (removing...
bool isTypeOperand() const
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
Expr * getArg(unsigned Arg)
getArg - Return the specified argument.
unsigned getNumArgs() const
getNumArgs - Return the number of actual arguments to this call.
bool isZero() const
isZero - Test whether the quantity equals zero.
QuantityType getQuantity() const
getQuantity - Get the raw integer representation of this quantity.
static CharUnits Zero()
Zero - Construct a CharUnits quantity of zero.
Represents a class template specialization, which refers to a class template with a given set of temp...
ClassTemplateDecl * getSpecializedTemplate() const
Retrieve the template that this specialization specializes.
const TemplateArgumentList & getTemplateArgs() const
Retrieve the template arguments of the class template specialization.
QualType getElementType() const
Expr * getCond() const
getCond - Return the expression representing the condition for the ?
llvm::APInt getSize() const
Return the constant array size as an APInt.
unsigned getNumColumns() const
Returns the number of columns in the matrix.
unsigned getNumRows() const
Returns the number of rows in the matrix.
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
DeclContext * getParent()
getParent - Returns the containing DeclContext.
bool isRequiresExprBody() const
bool isFileContext() const
bool isTranslationUnit() const
DeclContext * getRedeclContext()
getRedeclContext - Retrieve the context in which an entity conflicts with other entities of the same ...
FunctionDecl * getAsFunction() LLVM_READONLY
Returns the function itself, or the templated function if this is a function template.
SourceLocation getLocation() const
void setImplicit(bool I=true)
DeclContext * getDeclContext()
bool isInAnonymousNamespace() const
Module * getOwningModuleForLinkage() const
Get the module that owns this declaration for linkage purposes.
DeclContext * getLexicalDeclContext()
getLexicalDeclContext - The declaration context where this Decl was lexically declared (LexicalDC).
virtual Decl * getCanonicalDecl()
Retrieves the "canonical" declaration of the given declaration.
The name of a declaration.
IdentifierInfo * getAsIdentifierInfo() const
Retrieve the IdentifierInfo * stored in this declaration name, or null if this declaration name isn't...
const IdentifierInfo * getCXXLiteralIdentifier() const
If this name is the name of a literal operator, retrieve the identifier associated with it.
OverloadedOperatorKind getCXXOverloadedOperator() const
If this name is the name of an overloadable operator in C++ (e.g., operator+), retrieve the kind of o...
@ CXXConversionFunctionName
QualType getCXXNameType() const
If this name is one of the C++ names (of a constructor, destructor, or conversion function),...
NameKind getNameKind() const
Determine what kind of name this is.
const AssociatedConstraint & getTrailingRequiresClause() const
Get the constraint-expression introduced by the trailing requires-clause in the function/member decla...
Expr * getAddrSpaceExpr() const
QualType getPointeeType() const
Expr * getNumBitsExpr() const
NestedNameSpecifier getQualifier() const
Retrieve the nested-name-specifier that qualifies this declaration.
unsigned getNumTemplateArgs() const
DeclarationName getDeclName() const
Retrieve the name that this expression refers to.
TemplateArgumentLoc const * getTemplateArgs() const
Expr * getSizeExpr() const
Expr * getSizeExpr() const
QualType getElementType() const
Expr * getColumnExpr() const
Expr * getRowExpr() const
IdentifierOrOverloadedOperator getName() const
Represents a vector type where either the type or size is dependent.
Expr * getSizeExpr() const
VectorKind getVectorKind() const
SourceLocation getAttributeLoc() const
QualType getElementType() const
Concrete class used by the front-end to report problems and issues.
DiagnosticBuilder Report(SourceLocation Loc, unsigned DiagID)
Issue the message to the client.
llvm::APSInt getInitVal() const
This represents one expression.
llvm::APSInt EvaluateKnownConstInt(const ASTContext &Ctx) const
EvaluateKnownConstInt - Call EvaluateAsRValue and return the folded integer.
Expr * IgnoreParenImpCasts() LLVM_READONLY
Skip past any parentheses and implicit casts which might surround this expression until reaching a fi...
Expr * IgnoreImplicit() LLVM_READONLY
Skip past any implicit AST nodes which might surround this expression until reaching a fixed point.
Expr * IgnoreParens() LLVM_READONLY
Skip past any parentheses which might surround this expression until reaching a fixed point.
bool isInstantiationDependent() const
Whether this expression is instantiation-dependent, meaning that it depends in some way on.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
Represents a member of a struct/union/class.
bool isBitField() const
Determines whether this field is a bitfield.
unsigned getFieldIndex() const
Returns the index of this field within its record, as appropriate for passing to ASTRecordLayout::get...
const RecordDecl * getParent() const
Returns the parent of this field declaration, which is the struct in which this field is defined.
llvm::APFloat getValue() const
Represents a function declaration or definition.
const ParmVarDecl * getParamDecl(unsigned i) const
bool isMemberLikeConstrainedFriend() const
Determine whether a function is a friend function that cannot be redeclared outside of its class,...
FunctionTemplateDecl * getPrimaryTemplate() const
Retrieve the primary template that this function template specialization either specializes or was in...
const TemplateArgumentList * getTemplateSpecializationArgs() const
Retrieve the template arguments used to produce this function template specialization from the primar...
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
ValueDecl * getParameterPack() const
Get the parameter pack which this expression refers to.
Represents a prototype with parameter type info, e.g.
ExtParameterInfo getExtParameterInfo(unsigned I) const
ExceptionSpecificationType getExceptionSpecType() const
Get the kind of exception specification on this function.
unsigned getNumParams() const
Qualifiers getMethodQuals() const
QualType getParamType(unsigned i) const
unsigned getAArch64SMEAttributes() const
Return a bitmask describing the SME attributes on the function type, see AArch64SMETypeAttributes for...
bool isVariadic() const
Whether this function prototype is variadic.
Expr * getNoexceptExpr() const
Return the expression inside noexcept(expression), or a null pointer if there is none (because the ex...
bool isNothrow(bool ResultIfDependent=false) const
Determine whether this function type has a non-throwing exception specification.
ArrayRef< QualType > exceptions() const
bool hasInstantiationDependentExceptionSpec() const
Return whether this function has an instantiation-dependent exception spec.
bool hasExtParameterInfos() const
Is there any interesting extra information for any of the parameters of this function type?
RefQualifierKind getRefQualifier() const
Retrieve the ref-qualifier associated with this function type.
CallingConv getCC() const
bool getProducesResult() const
Interesting information about a specific parameter that can't simply be reflected in parameter's type...
bool isConsumed() const
Is this parameter considered "consumed" by Objective-C ARC?
ParameterABI getABI() const
Return the ABI treatment of this parameter.
FunctionType - C99 6.7.5.3 - Function Declarators.
ExtInfo getExtInfo() const
@ SME_PStateSMEnabledMask
@ SME_PStateSMCompatibleMask
@ SME_AgnosticZAStateMask
static ArmStateValue getArmZT0State(unsigned AttrBits)
static ArmStateValue getArmZAState(unsigned AttrBits)
QualType getReturnType() const
GlobalDecl - represents a global declaration.
CXXCtorType getCtorType() const
KernelReferenceKind getKernelReferenceKind() const
GlobalDecl getWithDecl(const Decl *D)
CXXDtorType getDtorType() const
const Decl * getDecl() const
One of these records is kept for each identifier that is lexed.
unsigned getLength() const
Efficiently return the length of this identifier info.
bool isStr(const char(&Str)[StrLen]) const
Return true if this is the identifier for the specified string.
StringRef getName() const
Return the actual identifier string.
const Expr * getSubExpr() const
Describes an C or C++ initializer list.
unsigned getNumInits() const
InitListExpr * getSyntacticForm() const
const Expr * getInit(unsigned Init) const
ItaniumMangleContext(ASTContext &C, DiagnosticsEngine &D, bool IsAux=false)
static ItaniumMangleContext * create(ASTContext &Context, DiagnosticsEngine &Diags, bool IsAux=false)
UnsignedOrNone(*)(ASTContext &, const NamedDecl *) DiscriminatorOverrideTy
bool isCompatibleWith(ClangABI Version) const
QualType getElementType() const
Returns type of the elements being stored in the matrix.
NestedNameSpecifier getQualifier() const
If the member name was qualified, retrieves the nested-name-specifier that precedes the member name.
ValueDecl * getMemberDecl() const
Retrieve the member declaration to which this expression refers.
const TemplateArgumentLoc * getTemplateArgs() const
Retrieve the template arguments provided as part of this template-id.
unsigned getNumTemplateArgs() const
Retrieve the number of template arguments provided as part of this template-id.
NestedNameSpecifier getQualifier() const
CXXRecordDecl * getMostRecentCXXRecordDecl() const
Note: this can trigger extra deserialization when external AST sources are used.
QualType getPointeeType() const
std::string Name
The name of this module.
StringRef getPrimaryModuleInterfaceName() const
Get the primary module interface name from a partition.
bool isModulePartition() const
Is this a module partition.
This represents a decl that may have a name.
IdentifierInfo * getIdentifier() const
Get the identifier that names this declaration, if there is one.
StringRef getName() const
Get the name of identifier for this declaration as a StringRef.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
Linkage getFormalLinkage() const
Get the linkage from a semantic point of view.
bool isCXXInstanceMember() const
Determine whether the given declaration is an instance member of a C++ class.
bool isExternallyVisible() const
Represent a C++ namespace.
bool isAnonymousNamespace() const
Returns true if this is an anonymous namespace declaration.
static NamespaceDecl * Create(ASTContext &C, DeclContext *DC, bool Inline, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, NamespaceDecl *PrevDecl, bool Nested)
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
const Type * getAsType() const
unsigned getIndex() const
Get the index of the template parameter within its parameter list.
unsigned getDepth() const
Get the nesting depth of the template parameter.
ObjCInterfaceDecl * getDecl() const
Get the declaration of this interface.
QualType getPointeeType() const
Gets the type pointed to by this ObjC pointer.
NestedNameSpecifier getQualifier() const
Fetches the nested-name qualifier, if one was given.
decls_iterator decls_begin() const
unsigned getNumDecls() const
Gets the number of declarations in the unresolved set.
TemplateArgumentLoc const * getTemplateArgs() const
unsigned getNumTemplateArgs() const
DeclarationName getName() const
Gets the name looked up.
A single parameter index whose accessors require each use to make explicit the parameter index encodi...
Represents a parameter to a function.
unsigned getFunctionScopeIndex() const
Returns the index of this parameter in its prototype or method scope.
unsigned getFunctionScopeDepth() const
QualType getPointeeType() const
A (possibly-)qualified type.
bool hasQualifiers() const
Determine whether this type has any qualifiers.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
Qualifiers getQualifiers() const
Retrieve the set of qualifiers applied to this type.
Qualifiers::ObjCLifetime getObjCLifetime() const
Returns lifetime attribute of this type.
QualType getCanonicalType() const
SplitQualType split() const
Divides a QualType into its unqualified type and a set of local qualifiers.
void * getAsOpaquePtr() const
QualType getSingleStepDesugaredType(const ASTContext &Context) const
Return the specified type with one level of "sugar" removed from the type.
The collection of all-type qualifiers we support.
unsigned getCVRQualifiers() const
@ OCL_Strong
Assigning into this object requires the old value to be released and the new value to be retained.
@ OCL_ExplicitNone
This object can be modified without requiring retains or releases.
@ OCL_None
There is no lifetime qualification on this type.
@ OCL_Weak
Reading or writing from this object requires a barrier call.
@ OCL_Autoreleasing
Assigning into this object requires a lifetime extension.
void removeObjCLifetime()
bool hasUnaligned() const
bool hasAddressSpace() const
PointerAuthQualifier getPointerAuth() const
ObjCLifetime getObjCLifetime() const
LangAS getAddressSpace() const
bool isLambda() const
Determine whether this record is a class describing a lambda function object.
field_range fields() const
decl_type * getFirstDecl()
Return the first declaration of this declaration or itself if this is the only declaration.
QualType getPointeeType() const
Encodes a location in the source.
StmtClass getStmtClass() const
SourceRange getSourceRange() const LLVM_READONLY
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpre...
const char * getStmtClassName() const
TemplateName getReplacement() const
TypedefNameDecl * getTypedefNameForAnonDecl() const
virtual const char * getFloat128Mangling() const
Return the mangled code of __float128.
virtual const char * getIbm128Mangling() const
Return the mangled code of __ibm128.
virtual const char * getLongDoubleMangling() const
Return the mangled code of long double.
virtual const char * getBFloat16Mangling() const
Return the mangled code of bfloat.
A template argument list.
unsigned size() const
Retrieve the number of template arguments in this template argument list.
Location wrapper for a TemplateArgument.
Represents a template argument.
QualType getStructuralValueType() const
Get the type of a StructuralValue.
QualType getParamTypeForDecl() const
Expr * getAsExpr() const
Retrieve the template argument as an expression.
bool isDependent() const
Whether this template argument is dependent on a template parameter such that its result can change f...
bool isInstantiationDependent() const
Whether this template argument is dependent on a template parameter.
pack_iterator pack_begin() const
Iterator referencing the first argument of a template argument pack.
QualType getAsType() const
Retrieve the type for a type template argument.
llvm::APSInt getAsIntegral() const
Retrieve the template argument as an integral value.
QualType getNullPtrType() const
Retrieve the type for null non-type template argument.
TemplateName getAsTemplate() const
Retrieve the template name for a template name argument.
unsigned pack_size() const
The number of template arguments in the given template argument pack.
QualType getIntegralType() const
Retrieve the type of the integral value.
ValueDecl * getAsDecl() const
Retrieve the declaration for a declaration non-type template argument.
ArrayRef< TemplateArgument > pack_elements() const
Iterator range referencing all of the elements of a template argument pack.
@ Declaration
The template argument is a declaration that was provided for a pointer, reference,...
@ Template
The template argument is a template name that was provided for a template template parameter.
@ StructuralValue
The template argument is a non-type template argument that can't be represented by the special-case D...
@ Pack
The template argument is actually a parameter pack.
@ TemplateExpansion
The template argument is a pack expansion of a template name that was provided for a template templat...
@ NullPtr
The template argument is a null pointer or null pointer to member that was provided for a non-type te...
@ Type
The template argument is a type.
@ Null
Represents an empty template argument, e.g., one that has not been deduced.
@ Integral
The template argument is an integral value stored in an llvm::APSInt that was provided for an integra...
@ Expression
The template argument is an expression, and we've not resolved it to one of the other forms yet,...
ArgKind getKind() const
Return the kind of stored template argument.
bool isPackExpansion() const
Determine whether this template argument is a pack expansion.
TemplateName getAsTemplateOrTemplatePattern() const
Retrieve the template argument as a template name; if the argument is a pack expansion,...
const APValue & getAsStructuralValue() const
Get the value of a StructuralValue.
The base class of all kinds of template declarations (e.g., class, function, etc.).
NamedDecl * getTemplatedDecl() const
Get the underlying, templated declaration.
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
Represents a C++ template name within the type system.
TemplateDecl * getAsTemplateDecl(bool IgnoreDeduced=false) const
Retrieve the underlying template declaration that this template name refers to, if known.
DependentTemplateName * getAsDependentTemplateName() const
Retrieve the underlying dependent template name structure, if any.
std::pair< TemplateName, DefaultArguments > getTemplateDeclAndDefaultArgs() const
Retrieves the underlying template name that this template name refers to, along with the deduced defa...
@ UsingTemplate
A template name that refers to a template declaration found through a specific using shadow declarati...
@ OverloadedTemplate
A set of overloaded template declarations.
@ Template
A single template declaration.
@ DependentTemplate
A dependent template name that has not been resolved to a template (or set of templates).
@ SubstTemplateTemplateParm
A template template parameter that has been substituted for some other template name.
@ SubstTemplateTemplateParmPack
A template template parameter pack that has been substituted for a template template argument pack,...
@ DeducedTemplate
A template name that refers to another TemplateName with deduced default arguments.
@ QualifiedTemplate
A qualified template name, where the qualification is kept to describe the source code as written.
@ AssumedTemplate
An unqualified-id that has been assumed to name a function template that will be found by ADL.
SubstTemplateTemplateParmStorage * getAsSubstTemplateTemplateParm() const
Retrieve the substituted template template parameter, if known.
Stores a list of template parameters for a TemplateDecl and its derived classes.
unsigned getDepth() const
Get the depth of this template parameter list in the set of template parameter lists.
const ASTTemplateArgumentListInfo * getTemplateArgsAsWritten() const
TemplateDecl * getNamedConcept() const
QualType getType() const
Return the type wrapped by this type source info.
ArrayRef< TypeSourceInfo * > getArgs() const
Retrieve the argument types.
TypeTrait getTrait() const
Determine which type trait this expression uses.
The base class of the type hierarchy.
bool isBooleanType() const
bool isSignedIntegerType() const
Return true if this is an integer type that is signed, according to C99 6.2.5p4 [char,...
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isVoidPointerType() const
bool isPointerType() const
bool isIntegerType() const
isIntegerType() does not include complex integers (a GCC extension).
bool isSVESizelessBuiltinType() const
Returns true for SVE scalable vector types.
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
const CXXRecordDecl * getPointeeCXXRecordDecl() const
If this is a pointer or reference to a RecordType, return the CXXRecordDecl that the type refers to.
const Type * getArrayElementTypeNoTypeQual() const
If this is an array type, return the element type of the array, potentially with type qualifiers miss...
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
bool isInstantiationDependentType() const
Determine whether this type is an instantiation-dependent type, meaning that the type involves a temp...
bool isSpecificBuiltinType(unsigned K) const
Test for a particular builtin type.
bool isBuiltinType() const
Helper methods to distinguish type categories.
bool isOpenCLSpecificType() const
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
const ArrayType * getAsArrayTypeUnsafe() const
A variant of getAs<> for array types which silently discards qualifiers from the outermost type.
bool isPointerOrReferenceType() const
const T * getAsCanonical() const
If this type is canonically the specified type, return its canonical type cast to that specified type...
TypeClass getTypeClass() const
const T * getAs() const
Member-template getAs<specific type>'.
bool isRecordType() const
QualType getArgumentType() const
bool isArgumentType() const
UnaryExprOrTypeTrait getKind() const
Expr * getSubExpr() const
static OverloadedOperatorKind getOverloadedOperator(Opcode Opc)
Retrieve the overloaded operator kind that corresponds to the given unary opcode.
A reference to a name which we were able to look up during parsing but could not resolve to a specifi...
bool requiresADL() const
True if this declaration should be extended by argument-dependent lookup.
DeclarationName getMemberName() const
Retrieve the name of the member that this expression refers to.
bool isArrow() const
Determine whether this member expression used the '->' operator; otherwise, it used the '.
Expr * getBase()
Retrieve the base object of this member expressions, e.g., the x in x.m.
bool isImplicitAccess() const
True if this is an implicit access, i.e., one in which the member being accessed was not written in t...
UnresolvedUsingTypenameDecl * getDecl() const
Represents a variable declaration or definition.
bool isInitCapture() const
Whether this variable is the implicit variable for a lambda init-capture.
Represents a variable template specialization, which refers to a variable template with a given set o...
Expr * getSizeExpr() const
Represents a GCC generic vector type.
unsigned getNumElements() const
VectorKind getVectorKind() const
QualType getElementType() const
A static requirement that can be used in a requires-expression to check properties of types and expre...
RequirementKind getKind() const
Defines the clang::TargetInfo interface.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
const internal::VariadicAllOfMatcher< Decl > decl
Matches declarations.
bool Sub(InterpState &S, CodePtr OpPC)
@ Number
Just a number, nothing else.
std::variant< struct RequiresDecl, struct HeaderDecl, struct UmbrellaDirDecl, struct ModuleDecl, struct ExcludeDecl, struct ExportDecl, struct ExportAsDecl, struct ExternModuleDecl, struct UseDecl, struct LinkDecl, struct ConfigMacrosDecl, struct ConflictDecl > Decl
All declarations that can appear in a module declaration.
The JSON file list parser is used to communicate input to InstallAPI.
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
@ OO_None
Not an overloaded operator.
@ NUM_OVERLOADED_OPERATORS
CXXCtorType
C++ constructor types.
@ Ctor_Base
Base object ctor.
@ Ctor_DefaultClosure
Default closure variant of a ctor.
@ Ctor_CopyingClosure
Copying closure variant of a ctor.
@ Ctor_Complete
Complete object ctor.
@ Ctor_Comdat
The COMDAT used for ctors.
@ Ctor_Unified
GCC-style unified dtor.
bool isa(CodeGen::Address addr)
llvm::StringRef getParameterABISpelling(ParameterABI kind)
RefQualifierKind
The kind of C++11 ref-qualifier associated with a function type.
@ RQ_None
No ref-qualifier was provided.
@ RQ_LValue
An lvalue ref-qualifier was provided (&).
@ RQ_RValue
An rvalue ref-qualifier was provided (&&).
@ TemplateName
The identifier is a template name. FIXME: Add an annotation for that.
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...
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
LanguageLinkage
Describes the different kinds of language linkage (C++ [dcl.link]) that an entity may have.
@ Dependent
Parse the block as a dependent block, which may be used in some template instantiations but not other...
@ Module
Module linkage, which indicates that the entity can be referred to from other translation units withi...
OptionalUnsigned< unsigned > UnsignedOrNone
bool isComputedNoexcept(ExceptionSpecificationType ESpecType)
@ Template
We are parsing a template declaration.
CXXDtorType
C++ destructor types.
@ Dtor_VectorDeleting
Vector deleting dtor.
@ Dtor_Comdat
The COMDAT used for dtors.
@ Dtor_Unified
GCC-style unified dtor.
@ Dtor_Base
Base object dtor.
@ Dtor_Complete
Complete object dtor.
@ Dtor_Deleting
Deleting dtor.
@ Type
The name was classified as a type.
@ Concept
The name was classified as a concept name.
LangAS
Defines the address space values used by the address space qualifier of QualType.
@ Deduced
The normal deduced case.
const char * getTraitSpelling(ExpressionTrait T) LLVM_READONLY
Return the spelling of the type trait TT. Never null.
bool declaresSameEntity(const Decl *D1, const Decl *D2)
Determine whether two declarations declare the same entity.
CallingConv
CallingConv - Specifies the calling convention that a function uses.
U cast(CodeGen::Address addr)
@ Other
Other implicit parameter.
@ EST_Dynamic
throw(T1, T2)
__UINTPTR_TYPE__ uintptr_t
An unsigned integer type with the property that any valid pointer to void can be converted to this ty...
Information about how to mangle a template argument.
bool NeedExactType
Do we need to mangle the template argument with an exactly correct type?
const NamedDecl * TemplateParameterToMangle
If we need to prefix the mangling with a mangling of the template parameter, the corresponding parame...
bool isOverloadable()
Determine whether the resolved template might be overloaded on its template parameter list.
TemplateArgManglingInfo(const CXXNameMangler &Mangler, TemplateName TN)
bool needToMangleTemplateParam(const NamedDecl *Param, const TemplateArgument &Arg)
Determine whether we need to prefix this <template-arg> mangling with a <template-param-decl>.
const NamedDecl * UnresolvedExpandedPack
const CXXNameMangler & Mangler
TemplateDecl * ResolvedTemplate
Info getArgInfo(unsigned ParamIdx, const TemplateArgument &Arg)
Determine information about how this template argument should be mangled.
const Expr * getTrailingRequiresClauseToMangle()
Determine if we should mangle a requires-clause after the template argument list.
bool SeenPackExpansionIntoNonPack
ArrayRef< TemplateArgumentLoc > arguments() const
const Expr * ConstraintExpr
const IdentifierInfo * getIdentifier() const
Returns the identifier to which this template name refers.
union clang::ReturnAdjustment::VirtualAdjustment Virtual
int64_t NonVirtual
The non-virtual adjustment from the derived object to its nearest virtual base.
const Type * Ty
The locally-unqualified type.
Qualifiers Quals
The local qualifiers.
union clang::ThisAdjustment::VirtualAdjustment Virtual
int64_t NonVirtual
The non-virtual adjustment from the derived object to its nearest virtual base.
The this pointer adjustment as well as an optional return adjustment for a thunk.
ThisAdjustment This
The this pointer adjustment.
ReturnAdjustment Return
The return adjustment.
struct clang::ReturnAdjustment::VirtualAdjustment::@103031170252120233124322035264172076254313213024 Itanium
int64_t VBaseOffsetOffset
The offset (in bytes), relative to the address point of the virtual base class offset.
struct clang::ThisAdjustment::VirtualAdjustment::@106065375072164260365214033034320247050276346205 Itanium
int64_t VCallOffsetOffset
The offset (in bytes), relative to the address point, of the virtual call offset.