start filling in the switch stmt


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23412 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/utils/TableGen/DAGISelEmitter.cpp b/utils/TableGen/DAGISelEmitter.cpp
index d0aac0b..a5ec845 100644
--- a/utils/TableGen/DAGISelEmitter.cpp
+++ b/utils/TableGen/DAGISelEmitter.cpp
@@ -1001,8 +1001,24 @@
      << "  case ISD::AssertZext:\n"
      << "    return Select(N->getOperand(0));\n";
     
-
+  // Group the patterns by their top-level opcodes.
+  std::map<Record*, std::vector<PatternToMatch*> > PatternsByOpcode;
+  for (unsigned i = 0, e = PatternsToMatch.size(); i != e; ++i)
+    PatternsByOpcode[PatternsToMatch[i].first->getOperator()]
+      .push_back(&PatternsToMatch[i]);
   
+  for (std::map<Record*, std::vector<PatternToMatch*> >::iterator
+       PBOI = PatternsByOpcode.begin(), E = PatternsByOpcode.end(); PBOI != E;
+       ++PBOI) {
+    const SDNodeInfo &OpcodeInfo = getSDNodeInfo(PBOI->first);
+    std::vector<PatternToMatch*> &Patterns = PBOI->second;
+    
+    OS << "  case " << OpcodeInfo.getEnumName() << ":\n";
+    
+    OS << "    break;\n";
+  }
+  
+
   OS << "  } // end of big switch.\n\n"
      << "  std::cerr << \"Cannot yet select: \";\n"
      << "  N->dump();\n"