Support case statement ranges.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@42648 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/CodeGen/CGStmt.cpp b/CodeGen/CGStmt.cpp
index 2b9a72b..c07929d 100644
--- a/CodeGen/CGStmt.cpp
+++ b/CodeGen/CGStmt.cpp
@@ -356,9 +356,21 @@
 
 void CodeGenFunction::EmitCaseStmt(const CaseStmt &S) {
   StartBlock("sw.bb");
-  llvm::Value *V = EmitScalarExpr(S.getLHS());
-  SwitchInsn->addCase(cast<llvm::ConstantInt>(V), Builder.GetInsertBlock());
-  assert (!S.getRHS() && "Case statement range is not yet supported");
+  llvm::BasicBlock *CaseDest = Builder.GetInsertBlock();
+  llvm::ConstantInt *LV = cast<llvm::ConstantInt>(EmitScalarExpr(S.getLHS()));
+  SwitchInsn->addCase(LV, CaseDest);
+  if (const Expr *R = S.getRHS()) {
+    llvm::ConstantInt *RV = cast<llvm::ConstantInt>(EmitScalarExpr(R));
+    llvm::APInt LHS = LV->getValue();
+    llvm::APInt RHS = RV->getValue();
+    LHS++;
+    while (LHS != RHS) {
+      SwitchInsn->addCase(llvm::ConstantInt::get(LHS), CaseDest);
+      LHS++;
+    }
+    SwitchInsn->addCase(llvm::ConstantInt::get(LHS), CaseDest);
+  }
+
   EmitStmt(S.getSubStmt());
 }