implement code generation for scalar stmt expressions.

llvm-svn: 41656
This commit is contained in:
Chris Lattner 2007-08-31 22:09:40 +00:00
parent cac27a5478
commit 04a913b958
3 changed files with 28 additions and 4 deletions

View File

@ -129,6 +129,8 @@ public:
return CGF.EmitCallExpr(E).getVal();
}
Value *VisitStmtExpr(const StmtExpr *E);
// Unary Operators.
Value *VisitPrePostIncDec(const UnaryOperator *E, bool isInc, bool isPre);
Value *VisitUnaryPostDec(const UnaryOperator *E) {
@ -437,6 +439,11 @@ Value *ScalarExprEmitter::EmitCastExpr(const Expr *E, QualType DestTy) {
DestTy);
}
Value *ScalarExprEmitter::VisitStmtExpr(const StmtExpr *E) {
return CGF.EmitCompoundStmt(*E->getSubStmt(), true).getVal();
}
//===----------------------------------------------------------------------===//
// Unary Operators
//===----------------------------------------------------------------------===//

View File

@ -60,12 +60,29 @@ void CodeGenFunction::EmitStmt(const Stmt *S) {
}
}
void CodeGenFunction::EmitCompoundStmt(const CompoundStmt &S) {
/// EmitCompoundStmt - Emit a compound statement {..} node. If GetLast is true,
/// this captures the expression result of the last sub-statement and returns it
/// (for use by the statement expression extension).
RValue CodeGenFunction::EmitCompoundStmt(const CompoundStmt &S, bool GetLast) {
// FIXME: handle vla's etc.
if (S.body_empty() || !isa<Expr>(S.body_back())) GetLast = false;
for (CompoundStmt::const_body_iterator I = S.body_begin(), E = S.body_end();
I != E; ++I)
for (CompoundStmt::const_body_iterator I = S.body_begin(),
E = S.body_end()-GetLast; I != E; ++I)
EmitStmt(*I);
if (!GetLast)
return RValue::get(0);
const Expr *Last = cast<Expr>(S.body_back());
if (!hasAggregateLLVMType(Last->getType()))
return RValue::get(EmitScalarExpr(Last));
assert(0 && "Unimp");
//else if (Last->getType()->isComplexType())
// EmitComplexExpr(Last);
//else
// EmitAggExpr(E, 0, false);
}
void CodeGenFunction::EmitBlock(llvm::BasicBlock *BB) {

View File

@ -265,7 +265,7 @@ public:
//===--------------------------------------------------------------------===//
void EmitStmt(const Stmt *S);
void EmitCompoundStmt(const CompoundStmt &S);
RValue EmitCompoundStmt(const CompoundStmt &S, bool GetLast = false);
void EmitLabelStmt(const LabelStmt &S);
void EmitGotoStmt(const GotoStmt &S);
void EmitIfStmt(const IfStmt &S);