]> granicus.if.org Git - clang/commitdiff
Fix double-destruction assertion to account for temporaries in conditionals
authorDouglas Gregor <dgregor@apple.com>
Thu, 24 Dec 2009 18:16:21 +0000 (18:16 +0000)
committerDouglas Gregor <dgregor@apple.com>
Thu, 24 Dec 2009 18:16:21 +0000 (18:16 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92134 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGTemporaries.cpp

index bfce1b0f747b515925df21bd820fec3b8810381a..bed843966e62037a3934bc7e66c121ed6def0b2f 100644 (file)
@@ -18,7 +18,8 @@ using namespace CodeGen;
 void CodeGenFunction::PushCXXTemporary(const CXXTemporary *Temporary,
                                        llvm::Value *Ptr) {
   assert((LiveTemporaries.empty() ||
-          LiveTemporaries.back().ThisPtr != Ptr) &&
+          LiveTemporaries.back().ThisPtr != Ptr ||
+          ConditionalBranchLevel) &&
          "Pushed the same temporary twice; AST is likely wrong");
   llvm::BasicBlock *DtorBlock = createBasicBlock("temp.dtor");