Prepare if
This commit is contained in:
@@ -144,6 +144,29 @@ void CodeGenVisitor::visit(FunctionDefinition* e) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CodeGenVisitor::visit(IfStatement* e) {
|
void CodeGenVisitor::visit(IfStatement* e) {
|
||||||
|
value_ = 0;
|
||||||
|
e->getCond()->accept(this);
|
||||||
|
|
||||||
|
llvm::Function* f = builder_->GetInsertBlock()->getParent();
|
||||||
|
llvm::BasicBlock* thenBB = llvm::BasicBlock::Create(llvm::getGlobalContext(), "then", f);
|
||||||
|
llvm::BasicBlock* elseBB = llvm::BasicBlock::Create(llvm::getGlobalContext(), "else");
|
||||||
|
llvm::BasicBlock* mergeBB = llvm::BasicBlock::Create(llvm::getGlobalContext(), "merge");
|
||||||
|
|
||||||
|
builder_->CreateCondBr(value_, thenBB, elseBB);
|
||||||
|
|
||||||
|
builder_->SetInsertPoint(thenBB);
|
||||||
|
e->getStmt()->accept(this);
|
||||||
|
|
||||||
|
builder_->CreateBr(mergeBB);
|
||||||
|
|
||||||
|
f->getBasicBlockList().push_back(elseBB);
|
||||||
|
builder_->SetInsertPoint(elseBB);
|
||||||
|
// we cna add an else part here later ...
|
||||||
|
|
||||||
|
builder_->CreateBr(mergeBB);
|
||||||
|
|
||||||
|
f->getBasicBlockList().push_back(mergeBB);
|
||||||
|
builder_->SetInsertPoint(mergeBB);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CodeGenVisitor::visit(ParameterList* e) {
|
void CodeGenVisitor::visit(ParameterList* e) {
|
||||||
|
|||||||
Reference in New Issue
Block a user