]> granicus.if.org Git - clang/commitdiff
PR11926 + duplicates: Fix crash in -Wuninitialized when using a compiler like
authorRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 30 Apr 2012 00:16:51 +0000 (00:16 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 30 Apr 2012 00:16:51 +0000 (00:16 +0000)
g++4.7, which reuses stack space allocated for temporaries. CFGElement::getAs
returns a suitably-cast version of 'this'. Patch by Markus Trippelsdorf!

No test: this code has the same observable behavior as the old code when built
with most compilers, and the tests were already failing when built with a
compiler for which this produced a broken binary.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@155803 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/UninitializedValues.cpp

index 6e5da2525973875678d4cf1b7d267c7201fe91cd..1c7e6b62f83643c07018e3912637b27926040816 100644 (file)
@@ -168,7 +168,8 @@ static const BinaryOperator *getLogicalOperatorInChain(const CFGBlock *block) {
   if (block->empty())
     return 0;
 
-  const CFGStmt *cstmt = block->front().getAs<CFGStmt>();
+  CFGElement front = block->front();
+  const CFGStmt *cstmt = front.getAs<CFGStmt>();
   if (!cstmt)
     return 0;