diff options
author | Mehdi Amini <mehdi.amini@apple.com> | 2016-11-15 21:47:11 +0000 |
---|---|---|
committer | Mehdi Amini <mehdi.amini@apple.com> | 2016-11-15 21:47:11 +0000 |
commit | 26168ad5c50f63e676184c207adf643ca7707ce9 (patch) | |
tree | 3c4847a4c3a68081ade2dbdcf32ed6762d6b2313 /clang/lib/AST/Expr.cpp | |
parent | bc9a574657acea3740e1765a9144a95aee3dca95 (diff) | |
download | bcm5719-llvm-26168ad5c50f63e676184c207adf643ca7707ce9.tar.gz bcm5719-llvm-26168ad5c50f63e676184c207adf643ca7707ce9.zip |
Improve handling of __FUNCTION__ and other predefined expression for Objective-C Blocks
Instead of always displaying the mangled name, try to do better
and get something closer to regular functions.
Differential Revision: https://reviews.llvm.org/D26522
llvm-svn: 287039
Diffstat (limited to 'clang/lib/AST/Expr.cpp')
-rw-r--r-- | clang/lib/AST/Expr.cpp | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index a269c9945e4..fbaa79aac0d 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/lib/AST/Expr.cpp @@ -518,20 +518,21 @@ std::string PredefinedExpr::ComputeName(IdentType IT, const Decl *CurrentDecl) { } return ""; } - if (auto *BD = dyn_cast<BlockDecl>(CurrentDecl)) { - std::unique_ptr<MangleContext> MC; - MC.reset(Context.createMangleContext()); - SmallString<256> Buffer; - llvm::raw_svector_ostream Out(Buffer); + if (isa<BlockDecl>(CurrentDecl)) { + // For blocks we only emit something if it is enclosed in a function + // For top-level block we'd like to include the name of variable, but we + // don't have it at this point. auto DC = CurrentDecl->getDeclContext(); if (DC->isFileContext()) - MC->mangleGlobalBlock(BD, /*ID*/ nullptr, Out); - else if (const auto *CD = dyn_cast<CXXConstructorDecl>(DC)) - MC->mangleCtorBlock(CD, /*CT*/ Ctor_Complete, BD, Out); - else if (const auto *DD = dyn_cast<CXXDestructorDecl>(DC)) - MC->mangleDtorBlock(DD, /*DT*/ Dtor_Complete, BD, Out); + return ""; + + SmallString<256> Buffer; + llvm::raw_svector_ostream Out(Buffer); + if (auto *DCFunc = dyn_cast<FunctionDecl>(DC)) + Out << ComputeName(IT, DCFunc) << "_block_invoke"; else - MC->mangleBlock(DC, BD, Out); + // For nested blocks, propagate up to the parent. + Out << ComputeName(IT, cast<BlockDecl>(DC)); return Out.str(); } if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(CurrentDecl)) { |