From: Daniel Dunbar Date: Thu, 5 Mar 2009 22:59:19 +0000 (+0000) Subject: Don't mangle names of local variables. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=fe345572459b69a6b680322fef504b4f8bd98dd7;p=clang Don't mangle names of local variables. - For one thing, this adds unneeded overhead; for another, this routine can be used to emit unnamed decls which we shouldn't try to mangle. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66212 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGDecl.cpp b/lib/CodeGen/CGDecl.cpp index 3dfb1821cc..e750d8a8d5 100644 --- a/lib/CodeGen/CGDecl.cpp +++ b/lib/CodeGen/CGDecl.cpp @@ -236,8 +236,8 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) { const llvm::Type *LTy = ConvertTypeForMem(Ty); if (isByRef) LTy = BuildByRefType(Ty, getContext().getDeclAlignInBytes(&D)); - llvm::AllocaInst *Alloc = - CreateTempAlloca(LTy, CGM.getMangledName(&D)); + llvm::AllocaInst *Alloc = + CreateTempAlloca(LTy, D.getNameAsString().c_str()); if (isByRef) Alloc->setAlignment(std::max(getContext().getDeclAlignInBytes(&D), getContext().getTypeAlign(getContext().VoidPtrTy) / 8)); diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index a187f8a51b..3f930feaaa 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -170,8 +170,10 @@ static void setGlobalVisibility(llvm::GlobalValue *GV, const char *CodeGenModule::getMangledName(const NamedDecl *ND) { llvm::SmallString<256> Name; llvm::raw_svector_ostream Out(Name); - if (!mangleName(ND, Context, Out)) + if (!mangleName(ND, Context, Out)) { + assert(ND->getIdentifier() && "Attempt to mangle unnamed decl."); return ND->getIdentifier()->getName(); + } Name += '\0'; return MangledNames.GetOrCreateValue(Name.begin(), Name.end()) diff --git a/test/Coverage/objc-language-features.inc b/test/Coverage/objc-language-features.inc index 25988f5e53..3b092ffbf4 100644 --- a/test/Coverage/objc-language-features.inc +++ b/test/Coverage/objc-language-features.inc @@ -51,6 +51,9 @@ @implementation A (Cat) @end +@interface B +@end + int f0(id x) { #ifndef IRGENABLE_GNU #ifndef IRGENABLE @@ -62,8 +65,13 @@ int f0(id x) { #ifndef IRGENABLE_GNU @try { @throw x; + } @catch(A *e) { @throw; + + // @catch param doesn't require name. + } @catch(B *) { + } @finally { ; }