diff options
author | Zhongxing Xu <xuzhongxing@gmail.com> | 2010-11-13 07:30:59 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@gmail.com> | 2010-11-13 07:30:59 +0000 |
commit | 9a4084dc06dc1b0033c461013bee3bae74be0555 (patch) | |
tree | a9eb8e3bd0a464e7d7f110e3e0995b5e87194085 /lib/Analysis/CFG.cpp | |
parent | 8b8d8c90f2d8ac651d14b57f116d20b3c911ac7f (diff) |
Do not add implicit dtors for CXXBindTemporaryExpr with elidable
CXXConstructExpr.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@118991 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/CFG.cpp')
-rw-r--r-- | lib/Analysis/CFG.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/lib/Analysis/CFG.cpp b/lib/Analysis/CFG.cpp index ef67d3b957..42e081628d 100644 --- a/lib/Analysis/CFG.cpp +++ b/lib/Analysis/CFG.cpp @@ -2579,11 +2579,18 @@ CFGBlock *CFGBuilder::VisitBinaryOperatorForTemporaryDtors(BinaryOperator *E) { return RHSBlock ? RHSBlock : LHSBlock; } +static bool hasElidableCXXConstructExpr(CXXBindTemporaryExpr *E) { + if (CXXConstructExpr *CE = dyn_cast<CXXConstructExpr>(E->getSubExpr())) + if (CE->isElidable()) + return true; + return false; +} + CFGBlock *CFGBuilder::VisitCXXBindTemporaryExprForTemporaryDtors( CXXBindTemporaryExpr *E, bool BindToTemporary) { // First add destructors for temporaries in subexpression. CFGBlock *B = VisitForTemporaryDtors(E->getSubExpr()); - if (!BindToTemporary) { + if (!BindToTemporary && !hasElidableCXXConstructExpr(E)) { // If lifetime of temporary is not prolonged (by assigning to constant // reference) add destructor for it. autoCreateBlock(); |