1 //===--- MicrosoftMangle.cpp - Microsoft Visual C++ Name Mangling ---------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This provides C++ name mangling targeting the Microsoft Visual C++ ABI. 11 // 12 //===----------------------------------------------------------------------===// 13 14 #include "clang/AST/Mangle.h" 15 #include "clang/AST/ASTContext.h" 16 #include "clang/AST/Attr.h" 17 #include "clang/AST/CharUnits.h" 18 #include "clang/AST/Decl.h" 19 #include "clang/AST/DeclCXX.h" 20 #include "clang/AST/DeclObjC.h" 21 #include "clang/AST/DeclTemplate.h" 22 #include "clang/AST/ExprCXX.h" 23 #include "clang/Basic/ABI.h" 24 #include "clang/Basic/DiagnosticOptions.h" 25 #include <map> 26 27 using namespace clang; 28 29 namespace { 30 31 static const FunctionDecl *getStructor(const FunctionDecl *fn) { 32 if (const FunctionTemplateDecl *ftd = fn->getPrimaryTemplate()) 33 return ftd->getTemplatedDecl(); 34 35 return fn; 36 } 37 38 /// MicrosoftCXXNameMangler - Manage the mangling of a single name for the 39 /// Microsoft Visual C++ ABI. 40 class MicrosoftCXXNameMangler { 41 MangleContext &Context; 42 raw_ostream &Out; 43 44 /// The "structor" is the top-level declaration being mangled, if 45 /// that's not a template specialization; otherwise it's the pattern 46 /// for that specialization. 47 const NamedDecl *Structor; 48 unsigned StructorType; 49 50 // FIXME: audit the performance of BackRefMap as it might do way too many 51 // copying of strings. 52 typedef std::map<std::string, unsigned> BackRefMap; 53 BackRefMap NameBackReferences; 54 bool UseNameBackReferences; 55 56 typedef llvm::DenseMap<void*, unsigned> ArgBackRefMap; 57 ArgBackRefMap TypeBackReferences; 58 59 ASTContext &getASTContext() const { return Context.getASTContext(); } 60 61 public: 62 MicrosoftCXXNameMangler(MangleContext &C, raw_ostream &Out_) 63 : Context(C), Out(Out_), 64 Structor(0), StructorType(-1), 65 UseNameBackReferences(true) { } 66 67 MicrosoftCXXNameMangler(MangleContext &C, raw_ostream &Out_, 68 const CXXDestructorDecl *D, CXXDtorType Type) 69 : Context(C), Out(Out_), 70 Structor(getStructor(D)), StructorType(Type), 71 UseNameBackReferences(true) { } 72 73 raw_ostream &getStream() const { return Out; } 74 75 void mangle(const NamedDecl *D, StringRef Prefix = "\01?"); 76 void mangleName(const NamedDecl *ND); 77 void mangleFunctionEncoding(const FunctionDecl *FD); 78 void mangleVariableEncoding(const VarDecl *VD); 79 void mangleNumber(int64_t Number); 80 void mangleNumber(const llvm::APSInt &Value); 81 void mangleType(QualType T, SourceRange Range, bool MangleQualifiers = true); 82 83 private: 84 void disableBackReferences() { UseNameBackReferences = false; } 85 void mangleUnqualifiedName(const NamedDecl *ND) { 86 mangleUnqualifiedName(ND, ND->getDeclName()); 87 } 88 void mangleUnqualifiedName(const NamedDecl *ND, DeclarationName Name); 89 void mangleSourceName(const IdentifierInfo *II); 90 void manglePostfix(const DeclContext *DC, bool NoFunction=false); 91 void mangleOperatorName(OverloadedOperatorKind OO, SourceLocation Loc); 92 void mangleCXXDtorType(CXXDtorType T); 93 void mangleQualifiers(Qualifiers Quals, bool IsMember); 94 void manglePointerQualifiers(Qualifiers Quals); 95 96 void mangleUnscopedTemplateName(const TemplateDecl *ND); 97 void mangleTemplateInstantiationName(const TemplateDecl *TD, 98 const SmallVectorImpl<TemplateArgumentLoc> &TemplateArgs); 99 void mangleObjCMethodName(const ObjCMethodDecl *MD); 100 void mangleLocalName(const FunctionDecl *FD); 101 102 void mangleArgumentType(QualType T, SourceRange Range); 103 104 // Declare manglers for every type class. 105 #define ABSTRACT_TYPE(CLASS, PARENT) 106 #define NON_CANONICAL_TYPE(CLASS, PARENT) 107 #define TYPE(CLASS, PARENT) void mangleType(const CLASS##Type *T, \ 108 SourceRange Range); 109 #include "clang/AST/TypeNodes.def" 110 #undef ABSTRACT_TYPE 111 #undef NON_CANONICAL_TYPE 112 #undef TYPE 113 114 void mangleType(const TagType*); 115 void mangleType(const FunctionType *T, const FunctionDecl *D, 116 bool IsStructor, bool IsInstMethod); 117 void mangleType(const ArrayType *T, bool IsGlobal); 118 void mangleExtraDimensions(QualType T); 119 void mangleFunctionClass(const FunctionDecl *FD); 120 void mangleCallingConvention(const FunctionType *T, bool IsInstMethod = false); 121 void mangleIntegerLiteral(const llvm::APSInt &Number, bool IsBoolean); 122 void mangleExpression(const Expr *E); 123 void mangleThrowSpecification(const FunctionProtoType *T); 124 125 void mangleTemplateArgs( 126 const SmallVectorImpl<TemplateArgumentLoc> &TemplateArgs); 127 128 }; 129 130 /// MicrosoftMangleContext - Overrides the default MangleContext for the 131 /// Microsoft Visual C++ ABI. 132 class MicrosoftMangleContext : public MangleContext { 133 public: 134 MicrosoftMangleContext(ASTContext &Context, 135 DiagnosticsEngine &Diags) : MangleContext(Context, Diags) { } 136 virtual bool shouldMangleDeclName(const NamedDecl *D); 137 virtual void mangleName(const NamedDecl *D, raw_ostream &Out); 138 virtual void mangleThunk(const CXXMethodDecl *MD, 139 const ThunkInfo &Thunk, 140 raw_ostream &); 141 virtual void mangleCXXDtorThunk(const CXXDestructorDecl *DD, CXXDtorType Type, 142 const ThisAdjustment &ThisAdjustment, 143 raw_ostream &); 144 virtual void mangleCXXVTable(const CXXRecordDecl *RD, 145 raw_ostream &); 146 virtual void mangleCXXVTT(const CXXRecordDecl *RD, 147 raw_ostream &); 148 virtual void mangleCXXCtorVTable(const CXXRecordDecl *RD, int64_t Offset, 149 const CXXRecordDecl *Type, 150 raw_ostream &); 151 virtual void mangleCXXRTTI(QualType T, raw_ostream &); 152 virtual void mangleCXXRTTIName(QualType T, raw_ostream &); 153 virtual void mangleCXXCtor(const CXXConstructorDecl *D, CXXCtorType Type, 154 raw_ostream &); 155 virtual void mangleCXXDtor(const CXXDestructorDecl *D, CXXDtorType Type, 156 raw_ostream &); 157 virtual void mangleReferenceTemporary(const clang::VarDecl *, 158 raw_ostream &); 159 }; 160 161 } 162 163 static bool isInCLinkageSpecification(const Decl *D) { 164 D = D->getCanonicalDecl(); 165 for (const DeclContext *DC = D->getDeclContext(); 166 !DC->isTranslationUnit(); DC = DC->getParent()) { 167 if (const LinkageSpecDecl *Linkage = dyn_cast<LinkageSpecDecl>(DC)) 168 return Linkage->getLanguage() == LinkageSpecDecl::lang_c; 169 } 170 171 return false; 172 } 173 174 bool MicrosoftMangleContext::shouldMangleDeclName(const NamedDecl *D) { 175 // In C, functions with no attributes never need to be mangled. Fastpath them. 176 if (!getASTContext().getLangOpts().CPlusPlus && !D->hasAttrs()) 177 return false; 178 179 // Any decl can be declared with __asm("foo") on it, and this takes precedence 180 // over all other naming in the .o file. 181 if (D->hasAttr<AsmLabelAttr>()) 182 return true; 183 184 // Clang's "overloadable" attribute extension to C/C++ implies name mangling 185 // (always) as does passing a C++ member function and a function 186 // whose name is not a simple identifier. 187 const FunctionDecl *FD = dyn_cast<FunctionDecl>(D); 188 if (FD && (FD->hasAttr<OverloadableAttr>() || isa<CXXMethodDecl>(FD) || 189 !FD->getDeclName().isIdentifier())) 190 return true; 191 192 // Otherwise, no mangling is done outside C++ mode. 193 if (!getASTContext().getLangOpts().CPlusPlus) 194 return false; 195 196 // Variables at global scope with internal linkage are not mangled. 197 if (!FD) { 198 const DeclContext *DC = D->getDeclContext(); 199 if (DC->isTranslationUnit() && D->getLinkage() == InternalLinkage) 200 return false; 201 } 202 203 // C functions and "main" are not mangled. 204 if ((FD && FD->isMain()) || isInCLinkageSpecification(D)) 205 return false; 206 207 return true; 208 } 209 210 void MicrosoftCXXNameMangler::mangle(const NamedDecl *D, 211 StringRef Prefix) { 212 // MSVC doesn't mangle C++ names the same way it mangles extern "C" names. 213 // Therefore it's really important that we don't decorate the 214 // name with leading underscores or leading/trailing at signs. So, by 215 // default, we emit an asm marker at the start so we get the name right. 216 // Callers can override this with a custom prefix. 217 218 // Any decl can be declared with __asm("foo") on it, and this takes precedence 219 // over all other naming in the .o file. 220 if (const AsmLabelAttr *ALA = D->getAttr<AsmLabelAttr>()) { 221 // If we have an asm name, then we use it as the mangling. 222 Out << '\01' << ALA->getLabel(); 223 return; 224 } 225 226 // <mangled-name> ::= ? <name> <type-encoding> 227 Out << Prefix; 228 mangleName(D); 229 if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) 230 mangleFunctionEncoding(FD); 231 else if (const VarDecl *VD = dyn_cast<VarDecl>(D)) 232 mangleVariableEncoding(VD); 233 else { 234 // TODO: Fields? Can MSVC even mangle them? 235 // Issue a diagnostic for now. 236 DiagnosticsEngine &Diags = Context.getDiags(); 237 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 238 "cannot mangle this declaration yet"); 239 Diags.Report(D->getLocation(), DiagID) 240 << D->getSourceRange(); 241 } 242 } 243 244 void MicrosoftCXXNameMangler::mangleFunctionEncoding(const FunctionDecl *FD) { 245 // <type-encoding> ::= <function-class> <function-type> 246 247 // Don't mangle in the type if this isn't a decl we should typically mangle. 248 if (!Context.shouldMangleDeclName(FD)) 249 return; 250 251 // We should never ever see a FunctionNoProtoType at this point. 252 // We don't even know how to mangle their types anyway :). 253 const FunctionProtoType *FT = FD->getType()->castAs<FunctionProtoType>(); 254 255 bool InStructor = false, InInstMethod = false; 256 const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD); 257 if (MD) { 258 if (MD->isInstance()) 259 InInstMethod = true; 260 if (isa<CXXConstructorDecl>(MD) || isa<CXXDestructorDecl>(MD)) 261 InStructor = true; 262 } 263 264 // First, the function class. 265 mangleFunctionClass(FD); 266 267 mangleType(FT, FD, InStructor, InInstMethod); 268 } 269 270 void MicrosoftCXXNameMangler::mangleVariableEncoding(const VarDecl *VD) { 271 // <type-encoding> ::= <storage-class> <variable-type> 272 // <storage-class> ::= 0 # private static member 273 // ::= 1 # protected static member 274 // ::= 2 # public static member 275 // ::= 3 # global 276 // ::= 4 # static local 277 278 // The first character in the encoding (after the name) is the storage class. 279 if (VD->isStaticDataMember()) { 280 // If it's a static member, it also encodes the access level. 281 switch (VD->getAccess()) { 282 default: 283 case AS_private: Out << '0'; break; 284 case AS_protected: Out << '1'; break; 285 case AS_public: Out << '2'; break; 286 } 287 } 288 else if (!VD->isStaticLocal()) 289 Out << '3'; 290 else 291 Out << '4'; 292 // Now mangle the type. 293 // <variable-type> ::= <type> <cvr-qualifiers> 294 // ::= <type> <pointee-cvr-qualifiers> # pointers, references 295 // Pointers and references are odd. The type of 'int * const foo;' gets 296 // mangled as 'QAHA' instead of 'PAHB', for example. 297 TypeLoc TL = VD->getTypeSourceInfo()->getTypeLoc(); 298 QualType Ty = TL.getType(); 299 if (Ty->isPointerType() || Ty->isReferenceType()) { 300 mangleType(Ty, TL.getSourceRange()); 301 mangleQualifiers(Ty->getPointeeType().getQualifiers(), false); 302 } else if (const ArrayType *AT = getASTContext().getAsArrayType(Ty)) { 303 // Global arrays are funny, too. 304 mangleType(AT, true); 305 mangleQualifiers(Ty.getQualifiers(), false); 306 } else { 307 mangleType(Ty.getLocalUnqualifiedType(), TL.getSourceRange()); 308 mangleQualifiers(Ty.getLocalQualifiers(), false); 309 } 310 } 311 312 void MicrosoftCXXNameMangler::mangleName(const NamedDecl *ND) { 313 // <name> ::= <unscoped-name> {[<named-scope>]+ | [<nested-name>]}? @ 314 const DeclContext *DC = ND->getDeclContext(); 315 316 // Always start with the unqualified name. 317 mangleUnqualifiedName(ND); 318 319 // If this is an extern variable declared locally, the relevant DeclContext 320 // is that of the containing namespace, or the translation unit. 321 if (isa<FunctionDecl>(DC) && ND->hasLinkage()) 322 while (!DC->isNamespace() && !DC->isTranslationUnit()) 323 DC = DC->getParent(); 324 325 manglePostfix(DC); 326 327 // Terminate the whole name with an '@'. 328 Out << '@'; 329 } 330 331 void MicrosoftCXXNameMangler::mangleNumber(int64_t Number) { 332 llvm::APSInt APSNumber(/*BitWidth=*/64, /*isUnsigned=*/false); 333 APSNumber = Number; 334 mangleNumber(APSNumber); 335 } 336 337 void MicrosoftCXXNameMangler::mangleNumber(const llvm::APSInt &Value) { 338 // <number> ::= [?] <decimal digit> # 1 <= Number <= 10 339 // ::= [?] <hex digit>+ @ # 0 or > 9; A = 0, B = 1, etc... 340 // ::= [?] @ # 0 (alternate mangling, not emitted by VC) 341 if (Value.isSigned() && Value.isNegative()) { 342 Out << '?'; 343 mangleNumber(llvm::APSInt(Value.abs())); 344 return; 345 } 346 llvm::APSInt Temp(Value); 347 // There's a special shorter mangling for 0, but Microsoft 348 // chose not to use it. Instead, 0 gets mangled as "A@". Oh well... 349 if (Value.uge(1) && Value.ule(10)) { 350 --Temp; 351 Temp.print(Out, false); 352 } else { 353 // We have to build up the encoding in reverse order, so it will come 354 // out right when we write it out. 355 char Encoding[64]; 356 char *EndPtr = Encoding+sizeof(Encoding); 357 char *CurPtr = EndPtr; 358 llvm::APSInt NibbleMask(Value.getBitWidth(), Value.isUnsigned()); 359 NibbleMask = 0xf; 360 do { 361 *--CurPtr = 'A' + Temp.And(NibbleMask).getLimitedValue(0xf); 362 Temp = Temp.lshr(4); 363 } while (Temp != 0); 364 Out.write(CurPtr, EndPtr-CurPtr); 365 Out << '@'; 366 } 367 } 368 369 static const TemplateDecl * 370 isTemplate(const NamedDecl *ND, 371 SmallVectorImpl<TemplateArgumentLoc> &TemplateArgs) { 372 // Check if we have a function template. 373 if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)){ 374 if (const TemplateDecl *TD = FD->getPrimaryTemplate()) { 375 if (FD->getTemplateSpecializationArgsAsWritten()) { 376 const ASTTemplateArgumentListInfo *ArgList = 377 FD->getTemplateSpecializationArgsAsWritten(); 378 TemplateArgs.append(ArgList->getTemplateArgs(), 379 ArgList->getTemplateArgs() + 380 ArgList->NumTemplateArgs); 381 } else { 382 const TemplateArgumentList *ArgList = 383 FD->getTemplateSpecializationArgs(); 384 TemplateArgumentListInfo LI; 385 for (unsigned i = 0, e = ArgList->size(); i != e; ++i) 386 TemplateArgs.push_back(TemplateArgumentLoc(ArgList->get(i), 387 FD->getTypeSourceInfo())); 388 } 389 return TD; 390 } 391 } 392 393 // Check if we have a class template. 394 if (const ClassTemplateSpecializationDecl *Spec = 395 dyn_cast<ClassTemplateSpecializationDecl>(ND)) { 396 TypeSourceInfo *TSI = Spec->getTypeAsWritten(); 397 if (TSI) { 398 TemplateSpecializationTypeLoc TSTL = 399 TSI->getTypeLoc().castAs<TemplateSpecializationTypeLoc>(); 400 TemplateArgumentListInfo LI(TSTL.getLAngleLoc(), TSTL.getRAngleLoc()); 401 for (unsigned i = 0, e = TSTL.getNumArgs(); i != e; ++i) 402 TemplateArgs.push_back(TSTL.getArgLoc(i)); 403 } else { 404 TemplateArgumentListInfo LI; 405 const TemplateArgumentList &ArgList = 406 Spec->getTemplateArgs(); 407 for (unsigned i = 0, e = ArgList.size(); i != e; ++i) 408 TemplateArgs.push_back(TemplateArgumentLoc(ArgList[i], 409 TemplateArgumentLocInfo())); 410 } 411 return Spec->getSpecializedTemplate(); 412 } 413 414 return 0; 415 } 416 417 void 418 MicrosoftCXXNameMangler::mangleUnqualifiedName(const NamedDecl *ND, 419 DeclarationName Name) { 420 // <unqualified-name> ::= <operator-name> 421 // ::= <ctor-dtor-name> 422 // ::= <source-name> 423 // ::= <template-name> 424 SmallVector<TemplateArgumentLoc, 2> TemplateArgs; 425 // Check if we have a template. 426 if (const TemplateDecl *TD = isTemplate(ND, TemplateArgs)) { 427 // We have a template. 428 // Here comes the tricky thing: if we need to mangle something like 429 // void foo(A::X<Y>, B::X<Y>), 430 // the X<Y> part is aliased. However, if you need to mangle 431 // void foo(A::X<A::Y>, A::X<B::Y>), 432 // the A::X<> part is not aliased. 433 // That said, from the mangler's perspective we have a structure like this: 434 // namespace[s] -> type[ -> template-parameters] 435 // but from the Clang perspective we have 436 // type [ -> template-parameters] 437 // \-> namespace[s] 438 // What we do is we create a new mangler, mangle the same type (without 439 // a namespace suffix) using the extra mangler with back references 440 // disabled (to avoid infinite recursion) and then use the mangled type 441 // name as a key to check the mangling of different types for aliasing. 442 443 std::string BackReferenceKey; 444 BackRefMap::iterator Found; 445 if (UseNameBackReferences) { 446 llvm::raw_string_ostream Stream(BackReferenceKey); 447 MicrosoftCXXNameMangler Extra(Context, Stream); 448 Extra.disableBackReferences(); 449 Extra.mangleUnqualifiedName(ND, Name); 450 Stream.flush(); 451 452 Found = NameBackReferences.find(BackReferenceKey); 453 } 454 if (!UseNameBackReferences || Found == NameBackReferences.end()) { 455 mangleTemplateInstantiationName(TD, TemplateArgs); 456 if (UseNameBackReferences && NameBackReferences.size() < 10) { 457 size_t Size = NameBackReferences.size(); 458 NameBackReferences[BackReferenceKey] = Size; 459 } 460 } else { 461 Out << Found->second; 462 } 463 return; 464 } 465 466 switch (Name.getNameKind()) { 467 case DeclarationName::Identifier: { 468 if (const IdentifierInfo *II = Name.getAsIdentifierInfo()) { 469 mangleSourceName(II); 470 break; 471 } 472 473 // Otherwise, an anonymous entity. We must have a declaration. 474 assert(ND && "mangling empty name without declaration"); 475 476 if (const NamespaceDecl *NS = dyn_cast<NamespaceDecl>(ND)) { 477 if (NS->isAnonymousNamespace()) { 478 Out << "?A@"; 479 break; 480 } 481 } 482 483 // We must have an anonymous struct. 484 const TagDecl *TD = cast<TagDecl>(ND); 485 if (const TypedefNameDecl *D = TD->getTypedefNameForAnonDecl()) { 486 assert(TD->getDeclContext() == D->getDeclContext() && 487 "Typedef should not be in another decl context!"); 488 assert(D->getDeclName().getAsIdentifierInfo() && 489 "Typedef was not named!"); 490 mangleSourceName(D->getDeclName().getAsIdentifierInfo()); 491 break; 492 } 493 494 // When VC encounters an anonymous type with no tag and no typedef, 495 // it literally emits '<unnamed-tag>'. 496 Out << "<unnamed-tag>"; 497 break; 498 } 499 500 case DeclarationName::ObjCZeroArgSelector: 501 case DeclarationName::ObjCOneArgSelector: 502 case DeclarationName::ObjCMultiArgSelector: 503 llvm_unreachable("Can't mangle Objective-C selector names here!"); 504 505 case DeclarationName::CXXConstructorName: 506 if (ND == Structor) { 507 assert(StructorType == Ctor_Complete && 508 "Should never be asked to mangle a ctor other than complete"); 509 } 510 Out << "?0"; 511 break; 512 513 case DeclarationName::CXXDestructorName: 514 if (ND == Structor) 515 // If the named decl is the C++ destructor we're mangling, 516 // use the type we were given. 517 mangleCXXDtorType(static_cast<CXXDtorType>(StructorType)); 518 else 519 // Otherwise, use the complete destructor name. This is relevant if a 520 // class with a destructor is declared within a destructor. 521 mangleCXXDtorType(Dtor_Complete); 522 break; 523 524 case DeclarationName::CXXConversionFunctionName: 525 // <operator-name> ::= ?B # (cast) 526 // The target type is encoded as the return type. 527 Out << "?B"; 528 break; 529 530 case DeclarationName::CXXOperatorName: 531 mangleOperatorName(Name.getCXXOverloadedOperator(), ND->getLocation()); 532 break; 533 534 case DeclarationName::CXXLiteralOperatorName: { 535 // FIXME: Was this added in VS2010? Does MS even know how to mangle this? 536 DiagnosticsEngine Diags = Context.getDiags(); 537 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 538 "cannot mangle this literal operator yet"); 539 Diags.Report(ND->getLocation(), DiagID); 540 break; 541 } 542 543 case DeclarationName::CXXUsingDirective: 544 llvm_unreachable("Can't mangle a using directive name!"); 545 } 546 } 547 548 void MicrosoftCXXNameMangler::manglePostfix(const DeclContext *DC, 549 bool NoFunction) { 550 // <postfix> ::= <unqualified-name> [<postfix>] 551 // ::= <substitution> [<postfix>] 552 553 if (!DC) return; 554 555 while (isa<LinkageSpecDecl>(DC)) 556 DC = DC->getParent(); 557 558 if (DC->isTranslationUnit()) 559 return; 560 561 if (const BlockDecl *BD = dyn_cast<BlockDecl>(DC)) { 562 Context.mangleBlock(BD, Out); 563 Out << '@'; 564 return manglePostfix(DC->getParent(), NoFunction); 565 } 566 567 if (NoFunction && (isa<FunctionDecl>(DC) || isa<ObjCMethodDecl>(DC))) 568 return; 569 else if (const ObjCMethodDecl *Method = dyn_cast<ObjCMethodDecl>(DC)) 570 mangleObjCMethodName(Method); 571 else if (const FunctionDecl *Func = dyn_cast<FunctionDecl>(DC)) 572 mangleLocalName(Func); 573 else { 574 mangleUnqualifiedName(cast<NamedDecl>(DC)); 575 manglePostfix(DC->getParent(), NoFunction); 576 } 577 } 578 579 void MicrosoftCXXNameMangler::mangleCXXDtorType(CXXDtorType T) { 580 switch (T) { 581 case Dtor_Deleting: 582 Out << "?_G"; 583 return; 584 case Dtor_Base: 585 // FIXME: We should be asked to mangle base dtors. 586 // However, fixing this would require larger changes to the CodeGenModule. 587 // Please put llvm_unreachable here when CGM is changed. 588 // For now, just mangle a base dtor the same way as a complete dtor... 589 case Dtor_Complete: 590 Out << "?1"; 591 return; 592 } 593 llvm_unreachable("Unsupported dtor type?"); 594 } 595 596 void MicrosoftCXXNameMangler::mangleOperatorName(OverloadedOperatorKind OO, 597 SourceLocation Loc) { 598 switch (OO) { 599 // ?0 # constructor 600 // ?1 # destructor 601 // <operator-name> ::= ?2 # new 602 case OO_New: Out << "?2"; break; 603 // <operator-name> ::= ?3 # delete 604 case OO_Delete: Out << "?3"; break; 605 // <operator-name> ::= ?4 # = 606 case OO_Equal: Out << "?4"; break; 607 // <operator-name> ::= ?5 # >> 608 case OO_GreaterGreater: Out << "?5"; break; 609 // <operator-name> ::= ?6 # << 610 case OO_LessLess: Out << "?6"; break; 611 // <operator-name> ::= ?7 # ! 612 case OO_Exclaim: Out << "?7"; break; 613 // <operator-name> ::= ?8 # == 614 case OO_EqualEqual: Out << "?8"; break; 615 // <operator-name> ::= ?9 # != 616 case OO_ExclaimEqual: Out << "?9"; break; 617 // <operator-name> ::= ?A # [] 618 case OO_Subscript: Out << "?A"; break; 619 // ?B # conversion 620 // <operator-name> ::= ?C # -> 621 case OO_Arrow: Out << "?C"; break; 622 // <operator-name> ::= ?D # * 623 case OO_Star: Out << "?D"; break; 624 // <operator-name> ::= ?E # ++ 625 case OO_PlusPlus: Out << "?E"; break; 626 // <operator-name> ::= ?F # -- 627 case OO_MinusMinus: Out << "?F"; break; 628 // <operator-name> ::= ?G # - 629 case OO_Minus: Out << "?G"; break; 630 // <operator-name> ::= ?H # + 631 case OO_Plus: Out << "?H"; break; 632 // <operator-name> ::= ?I # & 633 case OO_Amp: Out << "?I"; break; 634 // <operator-name> ::= ?J # ->* 635 case OO_ArrowStar: Out << "?J"; break; 636 // <operator-name> ::= ?K # / 637 case OO_Slash: Out << "?K"; break; 638 // <operator-name> ::= ?L # % 639 case OO_Percent: Out << "?L"; break; 640 // <operator-name> ::= ?M # < 641 case OO_Less: Out << "?M"; break; 642 // <operator-name> ::= ?N # <= 643 case OO_LessEqual: Out << "?N"; break; 644 // <operator-name> ::= ?O # > 645 case OO_Greater: Out << "?O"; break; 646 // <operator-name> ::= ?P # >= 647 case OO_GreaterEqual: Out << "?P"; break; 648 // <operator-name> ::= ?Q # , 649 case OO_Comma: Out << "?Q"; break; 650 // <operator-name> ::= ?R # () 651 case OO_Call: Out << "?R"; break; 652 // <operator-name> ::= ?S # ~ 653 case OO_Tilde: Out << "?S"; break; 654 // <operator-name> ::= ?T # ^ 655 case OO_Caret: Out << "?T"; break; 656 // <operator-name> ::= ?U # | 657 case OO_Pipe: Out << "?U"; break; 658 // <operator-name> ::= ?V # && 659 case OO_AmpAmp: Out << "?V"; break; 660 // <operator-name> ::= ?W # || 661 case OO_PipePipe: Out << "?W"; break; 662 // <operator-name> ::= ?X # *= 663 case OO_StarEqual: Out << "?X"; break; 664 // <operator-name> ::= ?Y # += 665 case OO_PlusEqual: Out << "?Y"; break; 666 // <operator-name> ::= ?Z # -= 667 case OO_MinusEqual: Out << "?Z"; break; 668 // <operator-name> ::= ?_0 # /= 669 case OO_SlashEqual: Out << "?_0"; break; 670 // <operator-name> ::= ?_1 # %= 671 case OO_PercentEqual: Out << "?_1"; break; 672 // <operator-name> ::= ?_2 # >>= 673 case OO_GreaterGreaterEqual: Out << "?_2"; break; 674 // <operator-name> ::= ?_3 # <<= 675 case OO_LessLessEqual: Out << "?_3"; break; 676 // <operator-name> ::= ?_4 # &= 677 case OO_AmpEqual: Out << "?_4"; break; 678 // <operator-name> ::= ?_5 # |= 679 case OO_PipeEqual: Out << "?_5"; break; 680 // <operator-name> ::= ?_6 # ^= 681 case OO_CaretEqual: Out << "?_6"; break; 682 // ?_7 # vftable 683 // ?_8 # vbtable 684 // ?_9 # vcall 685 // ?_A # typeof 686 // ?_B # local static guard 687 // ?_C # string 688 // ?_D # vbase destructor 689 // ?_E # vector deleting destructor 690 // ?_F # default constructor closure 691 // ?_G # scalar deleting destructor 692 // ?_H # vector constructor iterator 693 // ?_I # vector destructor iterator 694 // ?_J # vector vbase constructor iterator 695 // ?_K # virtual displacement map 696 // ?_L # eh vector constructor iterator 697 // ?_M # eh vector destructor iterator 698 // ?_N # eh vector vbase constructor iterator 699 // ?_O # copy constructor closure 700 // ?_P<name> # udt returning <name> 701 // ?_Q # <unknown> 702 // ?_R0 # RTTI Type Descriptor 703 // ?_R1 # RTTI Base Class Descriptor at (a,b,c,d) 704 // ?_R2 # RTTI Base Class Array 705 // ?_R3 # RTTI Class Hierarchy Descriptor 706 // ?_R4 # RTTI Complete Object Locator 707 // ?_S # local vftable 708 // ?_T # local vftable constructor closure 709 // <operator-name> ::= ?_U # new[] 710 case OO_Array_New: Out << "?_U"; break; 711 // <operator-name> ::= ?_V # delete[] 712 case OO_Array_Delete: Out << "?_V"; break; 713 714 case OO_Conditional: { 715 DiagnosticsEngine &Diags = Context.getDiags(); 716 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 717 "cannot mangle this conditional operator yet"); 718 Diags.Report(Loc, DiagID); 719 break; 720 } 721 722 case OO_None: 723 case NUM_OVERLOADED_OPERATORS: 724 llvm_unreachable("Not an overloaded operator"); 725 } 726 } 727 728 void MicrosoftCXXNameMangler::mangleSourceName(const IdentifierInfo *II) { 729 // <source name> ::= <identifier> @ 730 std::string key = II->getNameStart(); 731 BackRefMap::iterator Found; 732 if (UseNameBackReferences) 733 Found = NameBackReferences.find(key); 734 if (!UseNameBackReferences || Found == NameBackReferences.end()) { 735 Out << II->getName() << '@'; 736 if (UseNameBackReferences && NameBackReferences.size() < 10) { 737 size_t Size = NameBackReferences.size(); 738 NameBackReferences[key] = Size; 739 } 740 } else { 741 Out << Found->second; 742 } 743 } 744 745 void MicrosoftCXXNameMangler::mangleObjCMethodName(const ObjCMethodDecl *MD) { 746 Context.mangleObjCMethodName(MD, Out); 747 } 748 749 // Find out how many function decls live above this one and return an integer 750 // suitable for use as the number in a numbered anonymous scope. 751 // TODO: Memoize. 752 static unsigned getLocalNestingLevel(const FunctionDecl *FD) { 753 const DeclContext *DC = FD->getParent(); 754 int level = 1; 755 756 while (DC && !DC->isTranslationUnit()) { 757 if (isa<FunctionDecl>(DC) || isa<ObjCMethodDecl>(DC)) level++; 758 DC = DC->getParent(); 759 } 760 761 return 2*level; 762 } 763 764 void MicrosoftCXXNameMangler::mangleLocalName(const FunctionDecl *FD) { 765 // <nested-name> ::= <numbered-anonymous-scope> ? <mangled-name> 766 // <numbered-anonymous-scope> ::= ? <number> 767 // Even though the name is rendered in reverse order (e.g. 768 // A::B::C is rendered as C@B@A), VC numbers the scopes from outermost to 769 // innermost. So a method bar in class C local to function foo gets mangled 770 // as something like: 771 // ?bar@C@?1??foo@@YAXXZ@QAEXXZ 772 // This is more apparent when you have a type nested inside a method of a 773 // type nested inside a function. A method baz in class D local to method 774 // bar of class C local to function foo gets mangled as: 775 // ?baz@D@?3??bar@C@?1??foo@@YAXXZ@QAEXXZ@QAEXXZ 776 // This scheme is general enough to support GCC-style nested 777 // functions. You could have a method baz of class C inside a function bar 778 // inside a function foo, like so: 779 // ?baz@C@?3??bar@?1??foo@@YAXXZ@YAXXZ@QAEXXZ 780 int NestLevel = getLocalNestingLevel(FD); 781 Out << '?'; 782 mangleNumber(NestLevel); 783 Out << '?'; 784 mangle(FD, "?"); 785 } 786 787 void MicrosoftCXXNameMangler::mangleTemplateInstantiationName( 788 const TemplateDecl *TD, 789 const SmallVectorImpl<TemplateArgumentLoc> &TemplateArgs) { 790 // <template-name> ::= <unscoped-template-name> <template-args> 791 // ::= <substitution> 792 // Always start with the unqualified name. 793 794 // Templates have their own context for back references. 795 ArgBackRefMap OuterArgsContext; 796 BackRefMap OuterTemplateContext; 797 NameBackReferences.swap(OuterTemplateContext); 798 TypeBackReferences.swap(OuterArgsContext); 799 800 mangleUnscopedTemplateName(TD); 801 mangleTemplateArgs(TemplateArgs); 802 803 // Restore the previous back reference contexts. 804 NameBackReferences.swap(OuterTemplateContext); 805 TypeBackReferences.swap(OuterArgsContext); 806 } 807 808 void 809 MicrosoftCXXNameMangler::mangleUnscopedTemplateName(const TemplateDecl *TD) { 810 // <unscoped-template-name> ::= ?$ <unqualified-name> 811 Out << "?$"; 812 mangleUnqualifiedName(TD); 813 } 814 815 void 816 MicrosoftCXXNameMangler::mangleIntegerLiteral(const llvm::APSInt &Value, 817 bool IsBoolean) { 818 // <integer-literal> ::= $0 <number> 819 Out << "$0"; 820 // Make sure booleans are encoded as 0/1. 821 if (IsBoolean && Value.getBoolValue()) 822 mangleNumber(1); 823 else 824 mangleNumber(Value); 825 } 826 827 void 828 MicrosoftCXXNameMangler::mangleExpression(const Expr *E) { 829 // See if this is a constant expression. 830 llvm::APSInt Value; 831 if (E->isIntegerConstantExpr(Value, Context.getASTContext())) { 832 mangleIntegerLiteral(Value, E->getType()->isBooleanType()); 833 return; 834 } 835 836 // As bad as this diagnostic is, it's better than crashing. 837 DiagnosticsEngine &Diags = Context.getDiags(); 838 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 839 "cannot yet mangle expression type %0"); 840 Diags.Report(E->getExprLoc(), DiagID) 841 << E->getStmtClassName() << E->getSourceRange(); 842 } 843 844 void 845 MicrosoftCXXNameMangler::mangleTemplateArgs( 846 const SmallVectorImpl<TemplateArgumentLoc> &TemplateArgs) { 847 // <template-args> ::= {<type> | <integer-literal>}+ @ 848 unsigned NumTemplateArgs = TemplateArgs.size(); 849 for (unsigned i = 0; i < NumTemplateArgs; ++i) { 850 const TemplateArgumentLoc &TAL = TemplateArgs[i]; 851 const TemplateArgument &TA = TAL.getArgument(); 852 switch (TA.getKind()) { 853 case TemplateArgument::Null: 854 llvm_unreachable("Can't mangle null template arguments!"); 855 case TemplateArgument::Type: 856 mangleType(TA.getAsType(), TAL.getSourceRange()); 857 break; 858 case TemplateArgument::Integral: 859 mangleIntegerLiteral(TA.getAsIntegral(), 860 TA.getIntegralType()->isBooleanType()); 861 break; 862 case TemplateArgument::Expression: 863 mangleExpression(TA.getAsExpr()); 864 break; 865 case TemplateArgument::Template: 866 case TemplateArgument::TemplateExpansion: 867 case TemplateArgument::Declaration: 868 case TemplateArgument::NullPtr: 869 case TemplateArgument::Pack: { 870 // Issue a diagnostic. 871 DiagnosticsEngine &Diags = Context.getDiags(); 872 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 873 "cannot mangle this %select{ERROR|ERROR|pointer/reference|nullptr|" 874 "integral|template|template pack expansion|ERROR|parameter pack}0 " 875 "template argument yet"); 876 Diags.Report(TAL.getLocation(), DiagID) 877 << TA.getKind() 878 << TAL.getSourceRange(); 879 } 880 } 881 } 882 Out << '@'; 883 } 884 885 void MicrosoftCXXNameMangler::mangleQualifiers(Qualifiers Quals, 886 bool IsMember) { 887 // <cvr-qualifiers> ::= [E] [F] [I] <base-cvr-qualifiers> 888 // 'E' means __ptr64 (32-bit only); 'F' means __unaligned (32/64-bit only); 889 // 'I' means __restrict (32/64-bit). 890 // Note that the MSVC __restrict keyword isn't the same as the C99 restrict 891 // keyword! 892 // <base-cvr-qualifiers> ::= A # near 893 // ::= B # near const 894 // ::= C # near volatile 895 // ::= D # near const volatile 896 // ::= E # far (16-bit) 897 // ::= F # far const (16-bit) 898 // ::= G # far volatile (16-bit) 899 // ::= H # far const volatile (16-bit) 900 // ::= I # huge (16-bit) 901 // ::= J # huge const (16-bit) 902 // ::= K # huge volatile (16-bit) 903 // ::= L # huge const volatile (16-bit) 904 // ::= M <basis> # based 905 // ::= N <basis> # based const 906 // ::= O <basis> # based volatile 907 // ::= P <basis> # based const volatile 908 // ::= Q # near member 909 // ::= R # near const member 910 // ::= S # near volatile member 911 // ::= T # near const volatile member 912 // ::= U # far member (16-bit) 913 // ::= V # far const member (16-bit) 914 // ::= W # far volatile member (16-bit) 915 // ::= X # far const volatile member (16-bit) 916 // ::= Y # huge member (16-bit) 917 // ::= Z # huge const member (16-bit) 918 // ::= 0 # huge volatile member (16-bit) 919 // ::= 1 # huge const volatile member (16-bit) 920 // ::= 2 <basis> # based member 921 // ::= 3 <basis> # based const member 922 // ::= 4 <basis> # based volatile member 923 // ::= 5 <basis> # based const volatile member 924 // ::= 6 # near function (pointers only) 925 // ::= 7 # far function (pointers only) 926 // ::= 8 # near method (pointers only) 927 // ::= 9 # far method (pointers only) 928 // ::= _A <basis> # based function (pointers only) 929 // ::= _B <basis> # based function (far?) (pointers only) 930 // ::= _C <basis> # based method (pointers only) 931 // ::= _D <basis> # based method (far?) (pointers only) 932 // ::= _E # block (Clang) 933 // <basis> ::= 0 # __based(void) 934 // ::= 1 # __based(segment)? 935 // ::= 2 <name> # __based(name) 936 // ::= 3 # ? 937 // ::= 4 # ? 938 // ::= 5 # not really based 939 bool HasConst = Quals.hasConst(), 940 HasVolatile = Quals.hasVolatile(); 941 if (!IsMember) { 942 if (HasConst && HasVolatile) { 943 Out << 'D'; 944 } else if (HasVolatile) { 945 Out << 'C'; 946 } else if (HasConst) { 947 Out << 'B'; 948 } else { 949 Out << 'A'; 950 } 951 } else { 952 if (HasConst && HasVolatile) { 953 Out << 'T'; 954 } else if (HasVolatile) { 955 Out << 'S'; 956 } else if (HasConst) { 957 Out << 'R'; 958 } else { 959 Out << 'Q'; 960 } 961 } 962 963 // FIXME: For now, just drop all extension qualifiers on the floor. 964 } 965 966 void MicrosoftCXXNameMangler::manglePointerQualifiers(Qualifiers Quals) { 967 // <pointer-cvr-qualifiers> ::= P # no qualifiers 968 // ::= Q # const 969 // ::= R # volatile 970 // ::= S # const volatile 971 bool HasConst = Quals.hasConst(), 972 HasVolatile = Quals.hasVolatile(); 973 if (HasConst && HasVolatile) { 974 Out << 'S'; 975 } else if (HasVolatile) { 976 Out << 'R'; 977 } else if (HasConst) { 978 Out << 'Q'; 979 } else { 980 Out << 'P'; 981 } 982 } 983 984 void MicrosoftCXXNameMangler::mangleArgumentType(QualType T, 985 SourceRange Range) { 986 void *TypePtr = getASTContext().getCanonicalType(T).getAsOpaquePtr(); 987 ArgBackRefMap::iterator Found = TypeBackReferences.find(TypePtr); 988 989 if (Found == TypeBackReferences.end()) { 990 size_t OutSizeBefore = Out.GetNumBytesInBuffer(); 991 992 mangleType(T, Range, false); 993 994 // See if it's worth creating a back reference. 995 // Only types longer than 1 character are considered 996 // and only 10 back references slots are available: 997 bool LongerThanOneChar = (Out.GetNumBytesInBuffer() - OutSizeBefore > 1); 998 if (LongerThanOneChar && TypeBackReferences.size() < 10) { 999 size_t Size = TypeBackReferences.size(); 1000 TypeBackReferences[TypePtr] = Size; 1001 } 1002 } else { 1003 Out << Found->second; 1004 } 1005 } 1006 1007 void MicrosoftCXXNameMangler::mangleType(QualType T, SourceRange Range, 1008 bool MangleQualifiers) { 1009 // Only operate on the canonical type! 1010 T = getASTContext().getCanonicalType(T); 1011 1012 Qualifiers Quals = T.getLocalQualifiers(); 1013 // We have to mangle these now, while we still have enough information. 1014 if (T->isAnyPointerType() || T->isMemberPointerType() || 1015 T->isBlockPointerType()) { 1016 manglePointerQualifiers(Quals); 1017 } else if (Quals && MangleQualifiers) { 1018 mangleQualifiers(Quals, false); 1019 } 1020 1021 SplitQualType split = T.split(); 1022 const Type *ty = split.Ty; 1023 1024 // If we're mangling a qualified array type, push the qualifiers to 1025 // the element type. 1026 if (split.Quals && isa<ArrayType>(T)) { 1027 ty = Context.getASTContext().getAsArrayType(T); 1028 } 1029 1030 switch (ty->getTypeClass()) { 1031 #define ABSTRACT_TYPE(CLASS, PARENT) 1032 #define NON_CANONICAL_TYPE(CLASS, PARENT) \ 1033 case Type::CLASS: \ 1034 llvm_unreachable("can't mangle non-canonical type " #CLASS "Type"); \ 1035 return; 1036 #define TYPE(CLASS, PARENT) \ 1037 case Type::CLASS: \ 1038 mangleType(cast<CLASS##Type>(ty), Range); \ 1039 break; 1040 #include "clang/AST/TypeNodes.def" 1041 #undef ABSTRACT_TYPE 1042 #undef NON_CANONICAL_TYPE 1043 #undef TYPE 1044 } 1045 } 1046 1047 void MicrosoftCXXNameMangler::mangleType(const BuiltinType *T, 1048 SourceRange Range) { 1049 // <type> ::= <builtin-type> 1050 // <builtin-type> ::= X # void 1051 // ::= C # signed char 1052 // ::= D # char 1053 // ::= E # unsigned char 1054 // ::= F # short 1055 // ::= G # unsigned short (or wchar_t if it's not a builtin) 1056 // ::= H # int 1057 // ::= I # unsigned int 1058 // ::= J # long 1059 // ::= K # unsigned long 1060 // L # <none> 1061 // ::= M # float 1062 // ::= N # double 1063 // ::= O # long double (__float80 is mangled differently) 1064 // ::= _J # long long, __int64 1065 // ::= _K # unsigned long long, __int64 1066 // ::= _L # __int128 1067 // ::= _M # unsigned __int128 1068 // ::= _N # bool 1069 // _O # <array in parameter> 1070 // ::= _T # __float80 (Intel) 1071 // ::= _W # wchar_t 1072 // ::= _Z # __float80 (Digital Mars) 1073 switch (T->getKind()) { 1074 case BuiltinType::Void: Out << 'X'; break; 1075 case BuiltinType::SChar: Out << 'C'; break; 1076 case BuiltinType::Char_U: case BuiltinType::Char_S: Out << 'D'; break; 1077 case BuiltinType::UChar: Out << 'E'; break; 1078 case BuiltinType::Short: Out << 'F'; break; 1079 case BuiltinType::UShort: Out << 'G'; break; 1080 case BuiltinType::Int: Out << 'H'; break; 1081 case BuiltinType::UInt: Out << 'I'; break; 1082 case BuiltinType::Long: Out << 'J'; break; 1083 case BuiltinType::ULong: Out << 'K'; break; 1084 case BuiltinType::Float: Out << 'M'; break; 1085 case BuiltinType::Double: Out << 'N'; break; 1086 // TODO: Determine size and mangle accordingly 1087 case BuiltinType::LongDouble: Out << 'O'; break; 1088 case BuiltinType::LongLong: Out << "_J"; break; 1089 case BuiltinType::ULongLong: Out << "_K"; break; 1090 case BuiltinType::Int128: Out << "_L"; break; 1091 case BuiltinType::UInt128: Out << "_M"; break; 1092 case BuiltinType::Bool: Out << "_N"; break; 1093 case BuiltinType::WChar_S: 1094 case BuiltinType::WChar_U: Out << "_W"; break; 1095 1096 #define BUILTIN_TYPE(Id, SingletonId) 1097 #define PLACEHOLDER_TYPE(Id, SingletonId) \ 1098 case BuiltinType::Id: 1099 #include "clang/AST/BuiltinTypes.def" 1100 case BuiltinType::Dependent: 1101 llvm_unreachable("placeholder types shouldn't get to name mangling"); 1102 1103 case BuiltinType::ObjCId: Out << "PAUobjc_object@@"; break; 1104 case BuiltinType::ObjCClass: Out << "PAUobjc_class@@"; break; 1105 case BuiltinType::ObjCSel: Out << "PAUobjc_selector@@"; break; 1106 1107 case BuiltinType::OCLImage1d: Out << "PAUocl_image1d@@"; break; 1108 case BuiltinType::OCLImage1dArray: Out << "PAUocl_image1darray@@"; break; 1109 case BuiltinType::OCLImage1dBuffer: Out << "PAUocl_image1dbuffer@@"; break; 1110 case BuiltinType::OCLImage2d: Out << "PAUocl_image2d@@"; break; 1111 case BuiltinType::OCLImage2dArray: Out << "PAUocl_image2darray@@"; break; 1112 case BuiltinType::OCLImage3d: Out << "PAUocl_image3d@@"; break; 1113 case BuiltinType::OCLSampler: Out << "PAUocl_sampler@@"; break; 1114 case BuiltinType::OCLEvent: Out << "PAUocl_event@@"; break; 1115 1116 case BuiltinType::NullPtr: Out << "$$T"; break; 1117 1118 case BuiltinType::Char16: 1119 case BuiltinType::Char32: 1120 case BuiltinType::Half: { 1121 DiagnosticsEngine &Diags = Context.getDiags(); 1122 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1123 "cannot mangle this built-in %0 type yet"); 1124 Diags.Report(Range.getBegin(), DiagID) 1125 << T->getName(Context.getASTContext().getPrintingPolicy()) 1126 << Range; 1127 break; 1128 } 1129 } 1130 } 1131 1132 // <type> ::= <function-type> 1133 void MicrosoftCXXNameMangler::mangleType(const FunctionProtoType *T, 1134 SourceRange) { 1135 // Structors only appear in decls, so at this point we know it's not a 1136 // structor type. 1137 // FIXME: This may not be lambda-friendly. 1138 Out << "$$A6"; 1139 mangleType(T, NULL, false, false); 1140 } 1141 void MicrosoftCXXNameMangler::mangleType(const FunctionNoProtoType *T, 1142 SourceRange) { 1143 llvm_unreachable("Can't mangle K&R function prototypes"); 1144 } 1145 1146 void MicrosoftCXXNameMangler::mangleType(const FunctionType *T, 1147 const FunctionDecl *D, 1148 bool IsStructor, 1149 bool IsInstMethod) { 1150 // <function-type> ::= <this-cvr-qualifiers> <calling-convention> 1151 // <return-type> <argument-list> <throw-spec> 1152 const FunctionProtoType *Proto = cast<FunctionProtoType>(T); 1153 1154 // If this is a C++ instance method, mangle the CVR qualifiers for the 1155 // this pointer. 1156 if (IsInstMethod) 1157 mangleQualifiers(Qualifiers::fromCVRMask(Proto->getTypeQuals()), false); 1158 1159 mangleCallingConvention(T, IsInstMethod); 1160 1161 // <return-type> ::= <type> 1162 // ::= @ # structors (they have no declared return type) 1163 if (IsStructor) { 1164 if (isa<CXXDestructorDecl>(D) && D == Structor && 1165 StructorType == Dtor_Deleting) { 1166 // The scalar deleting destructor takes an extra int argument. 1167 // However, the FunctionType generated has 0 arguments. 1168 // FIXME: This is a temporary hack. 1169 // Maybe should fix the FunctionType creation instead? 1170 Out << "PAXI@Z"; 1171 return; 1172 } 1173 Out << '@'; 1174 } else { 1175 QualType Result = Proto->getResultType(); 1176 const Type* RT = Result.getTypePtr(); 1177 if (!RT->isAnyPointerType() && !RT->isReferenceType()) { 1178 if (Result.hasQualifiers() || !RT->isBuiltinType()) 1179 Out << '?'; 1180 if (!RT->isBuiltinType() && !Result.hasQualifiers()) { 1181 // Lack of qualifiers for user types is mangled as 'A'. 1182 Out << 'A'; 1183 } 1184 } 1185 1186 // FIXME: Get the source range for the result type. Or, better yet, 1187 // implement the unimplemented stuff so we don't need accurate source 1188 // location info anymore :). 1189 mangleType(Result, SourceRange()); 1190 } 1191 1192 // <argument-list> ::= X # void 1193 // ::= <type>+ @ 1194 // ::= <type>* Z # varargs 1195 if (Proto->getNumArgs() == 0 && !Proto->isVariadic()) { 1196 Out << 'X'; 1197 } else { 1198 if (D) { 1199 // If we got a decl, use the type-as-written to make sure arrays 1200 // get mangled right. Note that we can't rely on the TSI 1201 // existing if (for example) the parameter was synthesized. 1202 for (FunctionDecl::param_const_iterator Parm = D->param_begin(), 1203 ParmEnd = D->param_end(); Parm != ParmEnd; ++Parm) { 1204 TypeSourceInfo *TSI = (*Parm)->getTypeSourceInfo(); 1205 QualType Type = TSI ? TSI->getType() : (*Parm)->getType(); 1206 mangleArgumentType(Type, (*Parm)->getSourceRange()); 1207 } 1208 } else { 1209 // Happens for function pointer type arguments for example. 1210 for (FunctionProtoType::arg_type_iterator Arg = Proto->arg_type_begin(), 1211 ArgEnd = Proto->arg_type_end(); 1212 Arg != ArgEnd; ++Arg) 1213 mangleArgumentType(*Arg, SourceRange()); 1214 } 1215 // <builtin-type> ::= Z # ellipsis 1216 if (Proto->isVariadic()) 1217 Out << 'Z'; 1218 else 1219 Out << '@'; 1220 } 1221 1222 mangleThrowSpecification(Proto); 1223 } 1224 1225 void MicrosoftCXXNameMangler::mangleFunctionClass(const FunctionDecl *FD) { 1226 // <function-class> ::= A # private: near 1227 // ::= B # private: far 1228 // ::= C # private: static near 1229 // ::= D # private: static far 1230 // ::= E # private: virtual near 1231 // ::= F # private: virtual far 1232 // ::= G # private: thunk near 1233 // ::= H # private: thunk far 1234 // ::= I # protected: near 1235 // ::= J # protected: far 1236 // ::= K # protected: static near 1237 // ::= L # protected: static far 1238 // ::= M # protected: virtual near 1239 // ::= N # protected: virtual far 1240 // ::= O # protected: thunk near 1241 // ::= P # protected: thunk far 1242 // ::= Q # public: near 1243 // ::= R # public: far 1244 // ::= S # public: static near 1245 // ::= T # public: static far 1246 // ::= U # public: virtual near 1247 // ::= V # public: virtual far 1248 // ::= W # public: thunk near 1249 // ::= X # public: thunk far 1250 // ::= Y # global near 1251 // ::= Z # global far 1252 if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) { 1253 switch (MD->getAccess()) { 1254 default: 1255 case AS_private: 1256 if (MD->isStatic()) 1257 Out << 'C'; 1258 else if (MD->isVirtual()) 1259 Out << 'E'; 1260 else 1261 Out << 'A'; 1262 break; 1263 case AS_protected: 1264 if (MD->isStatic()) 1265 Out << 'K'; 1266 else if (MD->isVirtual()) 1267 Out << 'M'; 1268 else 1269 Out << 'I'; 1270 break; 1271 case AS_public: 1272 if (MD->isStatic()) 1273 Out << 'S'; 1274 else if (MD->isVirtual()) 1275 Out << 'U'; 1276 else 1277 Out << 'Q'; 1278 } 1279 } else 1280 Out << 'Y'; 1281 } 1282 void MicrosoftCXXNameMangler::mangleCallingConvention(const FunctionType *T, 1283 bool IsInstMethod) { 1284 // <calling-convention> ::= A # __cdecl 1285 // ::= B # __export __cdecl 1286 // ::= C # __pascal 1287 // ::= D # __export __pascal 1288 // ::= E # __thiscall 1289 // ::= F # __export __thiscall 1290 // ::= G # __stdcall 1291 // ::= H # __export __stdcall 1292 // ::= I # __fastcall 1293 // ::= J # __export __fastcall 1294 // The 'export' calling conventions are from a bygone era 1295 // (*cough*Win16*cough*) when functions were declared for export with 1296 // that keyword. (It didn't actually export them, it just made them so 1297 // that they could be in a DLL and somebody from another module could call 1298 // them.) 1299 CallingConv CC = T->getCallConv(); 1300 if (CC == CC_Default) { 1301 if (IsInstMethod) { 1302 const FunctionProtoType *FPT = 1303 T->getCanonicalTypeUnqualified().castAs<FunctionProtoType>(); 1304 bool isVariadic = FPT->isVariadic(); 1305 CC = getASTContext().getDefaultCXXMethodCallConv(isVariadic); 1306 } else { 1307 CC = CC_C; 1308 } 1309 } 1310 switch (CC) { 1311 default: 1312 llvm_unreachable("Unsupported CC for mangling"); 1313 case CC_Default: 1314 case CC_C: Out << 'A'; break; 1315 case CC_X86Pascal: Out << 'C'; break; 1316 case CC_X86ThisCall: Out << 'E'; break; 1317 case CC_X86StdCall: Out << 'G'; break; 1318 case CC_X86FastCall: Out << 'I'; break; 1319 } 1320 } 1321 void MicrosoftCXXNameMangler::mangleThrowSpecification( 1322 const FunctionProtoType *FT) { 1323 // <throw-spec> ::= Z # throw(...) (default) 1324 // ::= @ # throw() or __declspec/__attribute__((nothrow)) 1325 // ::= <type>+ 1326 // NOTE: Since the Microsoft compiler ignores throw specifications, they are 1327 // all actually mangled as 'Z'. (They're ignored because their associated 1328 // functionality isn't implemented, and probably never will be.) 1329 Out << 'Z'; 1330 } 1331 1332 void MicrosoftCXXNameMangler::mangleType(const UnresolvedUsingType *T, 1333 SourceRange Range) { 1334 // Probably should be mangled as a template instantiation; need to see what 1335 // VC does first. 1336 DiagnosticsEngine &Diags = Context.getDiags(); 1337 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1338 "cannot mangle this unresolved dependent type yet"); 1339 Diags.Report(Range.getBegin(), DiagID) 1340 << Range; 1341 } 1342 1343 // <type> ::= <union-type> | <struct-type> | <class-type> | <enum-type> 1344 // <union-type> ::= T <name> 1345 // <struct-type> ::= U <name> 1346 // <class-type> ::= V <name> 1347 // <enum-type> ::= W <size> <name> 1348 void MicrosoftCXXNameMangler::mangleType(const EnumType *T, SourceRange) { 1349 mangleType(cast<TagType>(T)); 1350 } 1351 void MicrosoftCXXNameMangler::mangleType(const RecordType *T, SourceRange) { 1352 mangleType(cast<TagType>(T)); 1353 } 1354 void MicrosoftCXXNameMangler::mangleType(const TagType *T) { 1355 switch (T->getDecl()->getTagKind()) { 1356 case TTK_Union: 1357 Out << 'T'; 1358 break; 1359 case TTK_Struct: 1360 case TTK_Interface: 1361 Out << 'U'; 1362 break; 1363 case TTK_Class: 1364 Out << 'V'; 1365 break; 1366 case TTK_Enum: 1367 Out << 'W'; 1368 Out << getASTContext().getTypeSizeInChars( 1369 cast<EnumDecl>(T->getDecl())->getIntegerType()).getQuantity(); 1370 break; 1371 } 1372 mangleName(T->getDecl()); 1373 } 1374 1375 // <type> ::= <array-type> 1376 // <array-type> ::= <pointer-cvr-qualifiers> <cvr-qualifiers> 1377 // [Y <dimension-count> <dimension>+] 1378 // <element-type> # as global 1379 // ::= Q <cvr-qualifiers> [Y <dimension-count> <dimension>+] 1380 // <element-type> # as param 1381 // It's supposed to be the other way around, but for some strange reason, it 1382 // isn't. Today this behavior is retained for the sole purpose of backwards 1383 // compatibility. 1384 void MicrosoftCXXNameMangler::mangleType(const ArrayType *T, bool IsGlobal) { 1385 // This isn't a recursive mangling, so now we have to do it all in this 1386 // one call. 1387 if (IsGlobal) { 1388 manglePointerQualifiers(T->getElementType().getQualifiers()); 1389 } else { 1390 Out << 'Q'; 1391 } 1392 mangleExtraDimensions(T->getElementType()); 1393 } 1394 void MicrosoftCXXNameMangler::mangleType(const ConstantArrayType *T, 1395 SourceRange) { 1396 mangleType(cast<ArrayType>(T), false); 1397 } 1398 void MicrosoftCXXNameMangler::mangleType(const VariableArrayType *T, 1399 SourceRange) { 1400 mangleType(cast<ArrayType>(T), false); 1401 } 1402 void MicrosoftCXXNameMangler::mangleType(const DependentSizedArrayType *T, 1403 SourceRange) { 1404 mangleType(cast<ArrayType>(T), false); 1405 } 1406 void MicrosoftCXXNameMangler::mangleType(const IncompleteArrayType *T, 1407 SourceRange) { 1408 mangleType(cast<ArrayType>(T), false); 1409 } 1410 void MicrosoftCXXNameMangler::mangleExtraDimensions(QualType ElementTy) { 1411 SmallVector<llvm::APInt, 3> Dimensions; 1412 for (;;) { 1413 if (const ConstantArrayType *CAT = 1414 getASTContext().getAsConstantArrayType(ElementTy)) { 1415 Dimensions.push_back(CAT->getSize()); 1416 ElementTy = CAT->getElementType(); 1417 } else if (ElementTy->isVariableArrayType()) { 1418 const VariableArrayType *VAT = 1419 getASTContext().getAsVariableArrayType(ElementTy); 1420 DiagnosticsEngine &Diags = Context.getDiags(); 1421 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1422 "cannot mangle this variable-length array yet"); 1423 Diags.Report(VAT->getSizeExpr()->getExprLoc(), DiagID) 1424 << VAT->getBracketsRange(); 1425 return; 1426 } else if (ElementTy->isDependentSizedArrayType()) { 1427 // The dependent expression has to be folded into a constant (TODO). 1428 const DependentSizedArrayType *DSAT = 1429 getASTContext().getAsDependentSizedArrayType(ElementTy); 1430 DiagnosticsEngine &Diags = Context.getDiags(); 1431 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1432 "cannot mangle this dependent-length array yet"); 1433 Diags.Report(DSAT->getSizeExpr()->getExprLoc(), DiagID) 1434 << DSAT->getBracketsRange(); 1435 return; 1436 } else if (ElementTy->isIncompleteArrayType()) continue; 1437 else break; 1438 } 1439 mangleQualifiers(ElementTy.getQualifiers(), false); 1440 // If there are any additional dimensions, mangle them now. 1441 if (Dimensions.size() > 0) { 1442 Out << 'Y'; 1443 // <dimension-count> ::= <number> # number of extra dimensions 1444 mangleNumber(Dimensions.size()); 1445 for (unsigned Dim = 0; Dim < Dimensions.size(); ++Dim) { 1446 mangleNumber(Dimensions[Dim].getLimitedValue()); 1447 } 1448 } 1449 mangleType(ElementTy.getLocalUnqualifiedType(), SourceRange()); 1450 } 1451 1452 // <type> ::= <pointer-to-member-type> 1453 // <pointer-to-member-type> ::= <pointer-cvr-qualifiers> <cvr-qualifiers> 1454 // <class name> <type> 1455 void MicrosoftCXXNameMangler::mangleType(const MemberPointerType *T, 1456 SourceRange Range) { 1457 QualType PointeeType = T->getPointeeType(); 1458 if (const FunctionProtoType *FPT = PointeeType->getAs<FunctionProtoType>()) { 1459 Out << '8'; 1460 mangleName(T->getClass()->castAs<RecordType>()->getDecl()); 1461 mangleType(FPT, NULL, false, true); 1462 } else { 1463 mangleQualifiers(PointeeType.getQualifiers(), true); 1464 mangleName(T->getClass()->castAs<RecordType>()->getDecl()); 1465 mangleType(PointeeType.getLocalUnqualifiedType(), Range); 1466 } 1467 } 1468 1469 void MicrosoftCXXNameMangler::mangleType(const TemplateTypeParmType *T, 1470 SourceRange Range) { 1471 DiagnosticsEngine &Diags = Context.getDiags(); 1472 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1473 "cannot mangle this template type parameter type yet"); 1474 Diags.Report(Range.getBegin(), DiagID) 1475 << Range; 1476 } 1477 1478 void MicrosoftCXXNameMangler::mangleType( 1479 const SubstTemplateTypeParmPackType *T, 1480 SourceRange Range) { 1481 DiagnosticsEngine &Diags = Context.getDiags(); 1482 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1483 "cannot mangle this substituted parameter pack yet"); 1484 Diags.Report(Range.getBegin(), DiagID) 1485 << Range; 1486 } 1487 1488 // <type> ::= <pointer-type> 1489 // <pointer-type> ::= <pointer-cvr-qualifiers> <cvr-qualifiers> <type> 1490 void MicrosoftCXXNameMangler::mangleType(const PointerType *T, 1491 SourceRange Range) { 1492 QualType PointeeTy = T->getPointeeType(); 1493 if (PointeeTy->isArrayType()) { 1494 // Pointers to arrays are mangled like arrays. 1495 mangleExtraDimensions(PointeeTy); 1496 } else if (const FunctionType *FT = PointeeTy->getAs<FunctionType>()) { 1497 // Function pointers are special. 1498 Out << '6'; 1499 mangleType(FT, NULL, false, false); 1500 } else { 1501 mangleQualifiers(PointeeTy.getQualifiers(), false); 1502 mangleType(PointeeTy, Range, false); 1503 } 1504 } 1505 void MicrosoftCXXNameMangler::mangleType(const ObjCObjectPointerType *T, 1506 SourceRange Range) { 1507 // Object pointers never have qualifiers. 1508 Out << 'A'; 1509 mangleType(T->getPointeeType(), Range); 1510 } 1511 1512 // <type> ::= <reference-type> 1513 // <reference-type> ::= A <cvr-qualifiers> <type> 1514 void MicrosoftCXXNameMangler::mangleType(const LValueReferenceType *T, 1515 SourceRange Range) { 1516 Out << 'A'; 1517 QualType PointeeTy = T->getPointeeType(); 1518 if (!PointeeTy.hasQualifiers()) 1519 // Lack of qualifiers is mangled as 'A'. 1520 Out << 'A'; 1521 mangleType(PointeeTy, Range); 1522 } 1523 1524 // <type> ::= <r-value-reference-type> 1525 // <r-value-reference-type> ::= $$Q <cvr-qualifiers> <type> 1526 void MicrosoftCXXNameMangler::mangleType(const RValueReferenceType *T, 1527 SourceRange Range) { 1528 Out << "$$Q"; 1529 QualType PointeeTy = T->getPointeeType(); 1530 if (!PointeeTy.hasQualifiers()) 1531 // Lack of qualifiers is mangled as 'A'. 1532 Out << 'A'; 1533 mangleType(PointeeTy, Range); 1534 } 1535 1536 void MicrosoftCXXNameMangler::mangleType(const ComplexType *T, 1537 SourceRange Range) { 1538 DiagnosticsEngine &Diags = Context.getDiags(); 1539 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1540 "cannot mangle this complex number type yet"); 1541 Diags.Report(Range.getBegin(), DiagID) 1542 << Range; 1543 } 1544 1545 void MicrosoftCXXNameMangler::mangleType(const VectorType *T, 1546 SourceRange Range) { 1547 DiagnosticsEngine &Diags = Context.getDiags(); 1548 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1549 "cannot mangle this vector type yet"); 1550 Diags.Report(Range.getBegin(), DiagID) 1551 << Range; 1552 } 1553 void MicrosoftCXXNameMangler::mangleType(const ExtVectorType *T, 1554 SourceRange Range) { 1555 DiagnosticsEngine &Diags = Context.getDiags(); 1556 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1557 "cannot mangle this extended vector type yet"); 1558 Diags.Report(Range.getBegin(), DiagID) 1559 << Range; 1560 } 1561 void MicrosoftCXXNameMangler::mangleType(const DependentSizedExtVectorType *T, 1562 SourceRange Range) { 1563 DiagnosticsEngine &Diags = Context.getDiags(); 1564 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1565 "cannot mangle this dependent-sized extended vector type yet"); 1566 Diags.Report(Range.getBegin(), DiagID) 1567 << Range; 1568 } 1569 1570 void MicrosoftCXXNameMangler::mangleType(const ObjCInterfaceType *T, 1571 SourceRange) { 1572 // ObjC interfaces have structs underlying them. 1573 Out << 'U'; 1574 mangleName(T->getDecl()); 1575 } 1576 1577 void MicrosoftCXXNameMangler::mangleType(const ObjCObjectType *T, 1578 SourceRange Range) { 1579 // We don't allow overloading by different protocol qualification, 1580 // so mangling them isn't necessary. 1581 mangleType(T->getBaseType(), Range); 1582 } 1583 1584 void MicrosoftCXXNameMangler::mangleType(const BlockPointerType *T, 1585 SourceRange Range) { 1586 Out << "_E"; 1587 1588 QualType pointee = T->getPointeeType(); 1589 mangleType(pointee->castAs<FunctionProtoType>(), NULL, false, false); 1590 } 1591 1592 void MicrosoftCXXNameMangler::mangleType(const InjectedClassNameType *T, 1593 SourceRange Range) { 1594 DiagnosticsEngine &Diags = Context.getDiags(); 1595 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1596 "cannot mangle this injected class name type yet"); 1597 Diags.Report(Range.getBegin(), DiagID) 1598 << Range; 1599 } 1600 1601 void MicrosoftCXXNameMangler::mangleType(const TemplateSpecializationType *T, 1602 SourceRange Range) { 1603 DiagnosticsEngine &Diags = Context.getDiags(); 1604 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1605 "cannot mangle this template specialization type yet"); 1606 Diags.Report(Range.getBegin(), DiagID) 1607 << Range; 1608 } 1609 1610 void MicrosoftCXXNameMangler::mangleType(const DependentNameType *T, 1611 SourceRange Range) { 1612 DiagnosticsEngine &Diags = Context.getDiags(); 1613 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1614 "cannot mangle this dependent name type yet"); 1615 Diags.Report(Range.getBegin(), DiagID) 1616 << Range; 1617 } 1618 1619 void MicrosoftCXXNameMangler::mangleType( 1620 const DependentTemplateSpecializationType *T, 1621 SourceRange Range) { 1622 DiagnosticsEngine &Diags = Context.getDiags(); 1623 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1624 "cannot mangle this dependent template specialization type yet"); 1625 Diags.Report(Range.getBegin(), DiagID) 1626 << Range; 1627 } 1628 1629 void MicrosoftCXXNameMangler::mangleType(const PackExpansionType *T, 1630 SourceRange Range) { 1631 DiagnosticsEngine &Diags = Context.getDiags(); 1632 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1633 "cannot mangle this pack expansion yet"); 1634 Diags.Report(Range.getBegin(), DiagID) 1635 << Range; 1636 } 1637 1638 void MicrosoftCXXNameMangler::mangleType(const TypeOfType *T, 1639 SourceRange Range) { 1640 DiagnosticsEngine &Diags = Context.getDiags(); 1641 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1642 "cannot mangle this typeof(type) yet"); 1643 Diags.Report(Range.getBegin(), DiagID) 1644 << Range; 1645 } 1646 1647 void MicrosoftCXXNameMangler::mangleType(const TypeOfExprType *T, 1648 SourceRange Range) { 1649 DiagnosticsEngine &Diags = Context.getDiags(); 1650 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1651 "cannot mangle this typeof(expression) yet"); 1652 Diags.Report(Range.getBegin(), DiagID) 1653 << Range; 1654 } 1655 1656 void MicrosoftCXXNameMangler::mangleType(const DecltypeType *T, 1657 SourceRange Range) { 1658 DiagnosticsEngine &Diags = Context.getDiags(); 1659 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1660 "cannot mangle this decltype() yet"); 1661 Diags.Report(Range.getBegin(), DiagID) 1662 << Range; 1663 } 1664 1665 void MicrosoftCXXNameMangler::mangleType(const UnaryTransformType *T, 1666 SourceRange Range) { 1667 DiagnosticsEngine &Diags = Context.getDiags(); 1668 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1669 "cannot mangle this unary transform type yet"); 1670 Diags.Report(Range.getBegin(), DiagID) 1671 << Range; 1672 } 1673 1674 void MicrosoftCXXNameMangler::mangleType(const AutoType *T, SourceRange Range) { 1675 DiagnosticsEngine &Diags = Context.getDiags(); 1676 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1677 "cannot mangle this 'auto' type yet"); 1678 Diags.Report(Range.getBegin(), DiagID) 1679 << Range; 1680 } 1681 1682 void MicrosoftCXXNameMangler::mangleType(const AtomicType *T, 1683 SourceRange Range) { 1684 DiagnosticsEngine &Diags = Context.getDiags(); 1685 unsigned DiagID = Diags.getCustomDiagID(DiagnosticsEngine::Error, 1686 "cannot mangle this C11 atomic type yet"); 1687 Diags.Report(Range.getBegin(), DiagID) 1688 << Range; 1689 } 1690 1691 void MicrosoftMangleContext::mangleName(const NamedDecl *D, 1692 raw_ostream &Out) { 1693 assert((isa<FunctionDecl>(D) || isa<VarDecl>(D)) && 1694 "Invalid mangleName() call, argument is not a variable or function!"); 1695 assert(!isa<CXXConstructorDecl>(D) && !isa<CXXDestructorDecl>(D) && 1696 "Invalid mangleName() call on 'structor decl!"); 1697 1698 PrettyStackTraceDecl CrashInfo(D, SourceLocation(), 1699 getASTContext().getSourceManager(), 1700 "Mangling declaration"); 1701 1702 MicrosoftCXXNameMangler Mangler(*this, Out); 1703 return Mangler.mangle(D); 1704 } 1705 void MicrosoftMangleContext::mangleThunk(const CXXMethodDecl *MD, 1706 const ThunkInfo &Thunk, 1707 raw_ostream &) { 1708 unsigned DiagID = getDiags().getCustomDiagID(DiagnosticsEngine::Error, 1709 "cannot mangle thunk for this method yet"); 1710 getDiags().Report(MD->getLocation(), DiagID); 1711 } 1712 void MicrosoftMangleContext::mangleCXXDtorThunk(const CXXDestructorDecl *DD, 1713 CXXDtorType Type, 1714 const ThisAdjustment &, 1715 raw_ostream &) { 1716 unsigned DiagID = getDiags().getCustomDiagID(DiagnosticsEngine::Error, 1717 "cannot mangle thunk for this destructor yet"); 1718 getDiags().Report(DD->getLocation(), DiagID); 1719 } 1720 void MicrosoftMangleContext::mangleCXXVTable(const CXXRecordDecl *RD, 1721 raw_ostream &Out) { 1722 // <mangled-name> ::= ? <operator-name> <class-name> <storage-class> 1723 // <cvr-qualifiers> [<name>] @ 1724 // <operator-name> ::= _7 # vftable 1725 // ::= _8 # vbtable 1726 // NOTE: <cvr-qualifiers> here is always 'B' (const). <storage-class> 1727 // is always '6' for vftables and '7' for vbtables. (The difference is 1728 // beyond me.) 1729 // TODO: vbtables. 1730 MicrosoftCXXNameMangler Mangler(*this, Out); 1731 Mangler.getStream() << "\01??_7"; 1732 Mangler.mangleName(RD); 1733 Mangler.getStream() << "6B"; 1734 // TODO: If the class has more than one vtable, mangle in the class it came 1735 // from. 1736 Mangler.getStream() << '@'; 1737 } 1738 void MicrosoftMangleContext::mangleCXXVTT(const CXXRecordDecl *RD, 1739 raw_ostream &) { 1740 llvm_unreachable("The MS C++ ABI does not have virtual table tables!"); 1741 } 1742 void MicrosoftMangleContext::mangleCXXCtorVTable(const CXXRecordDecl *RD, 1743 int64_t Offset, 1744 const CXXRecordDecl *Type, 1745 raw_ostream &) { 1746 llvm_unreachable("The MS C++ ABI does not have constructor vtables!"); 1747 } 1748 void MicrosoftMangleContext::mangleCXXRTTI(QualType T, 1749 raw_ostream &) { 1750 // FIXME: Give a location... 1751 unsigned DiagID = getDiags().getCustomDiagID(DiagnosticsEngine::Error, 1752 "cannot mangle RTTI descriptors for type %0 yet"); 1753 getDiags().Report(DiagID) 1754 << T.getBaseTypeIdentifier(); 1755 } 1756 void MicrosoftMangleContext::mangleCXXRTTIName(QualType T, 1757 raw_ostream &) { 1758 // FIXME: Give a location... 1759 unsigned DiagID = getDiags().getCustomDiagID(DiagnosticsEngine::Error, 1760 "cannot mangle the name of type %0 into RTTI descriptors yet"); 1761 getDiags().Report(DiagID) 1762 << T.getBaseTypeIdentifier(); 1763 } 1764 void MicrosoftMangleContext::mangleCXXCtor(const CXXConstructorDecl *D, 1765 CXXCtorType Type, 1766 raw_ostream & Out) { 1767 MicrosoftCXXNameMangler mangler(*this, Out); 1768 mangler.mangle(D); 1769 } 1770 void MicrosoftMangleContext::mangleCXXDtor(const CXXDestructorDecl *D, 1771 CXXDtorType Type, 1772 raw_ostream & Out) { 1773 MicrosoftCXXNameMangler mangler(*this, Out, D, Type); 1774 mangler.mangle(D); 1775 } 1776 void MicrosoftMangleContext::mangleReferenceTemporary(const clang::VarDecl *VD, 1777 raw_ostream &) { 1778 unsigned DiagID = getDiags().getCustomDiagID(DiagnosticsEngine::Error, 1779 "cannot mangle this reference temporary yet"); 1780 getDiags().Report(VD->getLocation(), DiagID); 1781 } 1782 1783 MangleContext *clang::createMicrosoftMangleContext(ASTContext &Context, 1784 DiagnosticsEngine &Diags) { 1785 return new MicrosoftMangleContext(Context, Diags); 1786 } 1787