[cfe-commits] r57761 - /cfe/trunk/lib/Analysis/GRExprEngine.cpp
Ted Kremenek
kremenek at apple.com
Fri Oct 17 21:15:35 PDT 2008
Author: kremenek
Date: Fri Oct 17 23:15:35 2008
New Revision: 57761
URL: http://llvm.org/viewvc/llvm-project?rev=57761&view=rev
Log:
Generalize VisitLValue: not only can CallExprs and ObjCMessageExprs return aggregate temporaries, so can many other expressions.
Modified:
cfe/trunk/lib/Analysis/GRExprEngine.cpp
Modified: cfe/trunk/lib/Analysis/GRExprEngine.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Analysis/GRExprEngine.cpp?rev=57761&r1=57760&r2=57761&view=diff
==============================================================================
--- cfe/trunk/lib/Analysis/GRExprEngine.cpp (original)
+++ cfe/trunk/lib/Analysis/GRExprEngine.cpp Fri Oct 17 23:15:35 2008
@@ -408,9 +408,6 @@
}
switch (Ex->getStmtClass()) {
- default:
- Ex->dump();
- assert(0 && "Other kinds of expressions do not have lvalue.");
case Stmt::ArraySubscriptExprClass:
VisitArraySubscriptExpr(cast<ArraySubscriptExpr>(Ex), Pred, Dst, true);
@@ -447,16 +444,16 @@
Dst.Add(Pred);
return;
- case Stmt::CallExprClass:
- case Stmt::ObjCMessageExprClass:
- // Function calls and message expressions that return temporaries
- // that are objects can be called in this context. We need to
- // enhance our support of struct return values, so right now just
- // do a regular visit.
- assert (!Ex->getType()->isIntegerType());
- assert (!Ex->getType()->isPointerType());
- Visit(Ex, Pred, Dst);
+ default:
+ // Arbitrary subexpressions can return aggregate temporaries that
+ // can be used in a lvalue context. We need to enhance our support
+ // of such temporaries in both the environment and the store, so right
+ // now we just do a regular visit.
+ assert (Ex->getType()->isAggregateType() &&
+ "Other kinds of expressions with non-aggregate types do not "
+ "have lvalues.");
+ Visit(Ex, Pred, Dst);
}
}
More information about the cfe-commits
mailing list