diff options
author | Wei Pan <wei.pan@intel.com> | 2013-08-26 14:27:34 +0000 |
---|---|---|
committer | Wei Pan <wei.pan@intel.com> | 2013-08-26 14:27:34 +0000 |
commit | 8d6b19a518b68a045e3db4e06b3ddc5023ffd046 (patch) | |
tree | 01b9d2fd095cbc7acabfe6821fb0aeec604510aa /clang/lib/AST | |
parent | 91780dec58c88880cc264a4cdd1f8ba3a420159b (diff) | |
download | bcm5719-llvm-8d6b19a518b68a045e3db4e06b3ddc5023ffd046.tar.gz bcm5719-llvm-8d6b19a518b68a045e3db4e06b3ddc5023ffd046.zip |
Handle predefined expression for a captured statement
- __func__ or __FUNCTION__ returns captured statement's parent
function name, not the one compiler generated.
Differential Revision: http://llvm-reviews.chandlerc.com/D1491
Reviewed by bkramer
llvm-svn: 189219
Diffstat (limited to 'clang/lib/AST')
-rw-r--r-- | clang/lib/AST/Expr.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index 0ba117e3e2a..ea91fbec4f8 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/lib/AST/Expr.cpp @@ -604,6 +604,16 @@ std::string PredefinedExpr::ComputeName(IdentType IT, const Decl *CurrentDecl) { Out.flush(); return Name.str().str(); } + if (const CapturedDecl *CD = dyn_cast<CapturedDecl>(CurrentDecl)) { + for (const DeclContext *DC = CD->getParent(); DC; DC = DC->getParent()) + // Skip to its enclosing function or method, but not its enclosing + // CapturedDecl. + if (DC->isFunctionOrMethod() && (DC->getDeclKind() != Decl::Captured)) { + const Decl *D = Decl::castFromDeclContext(DC); + return ComputeName(IT, D); + } + llvm_unreachable("CapturedDecl not inside a function or method"); + } if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(CurrentDecl)) { SmallString<256> Name; llvm::raw_svector_ostream Out(Name); |