OSDN Git Service

make sure that empty diag groups get known by clang.
authorChris Lattner <sabre@nondot.org>
Wed, 15 Apr 2009 22:33:02 +0000 (22:33 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 15 Apr 2009 22:33:02 +0000 (22:33 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@69235 91177308-0d34-0410-b5e6-96231b3b80d8

utils/TableGen/ClangDiagnosticsEmitter.cpp

index d0ca5a1..045eb7a 100644 (file)
@@ -66,9 +66,8 @@ void ClangDiagGroupsEmitter::run(std::ostream &OS) {
   // groups to diags in the group.
   std::map<std::string, std::vector<const Record*> > DiagsInGroup;
   
-  const std::vector<Record*> &Diags =
+  std::vector<Record*> Diags =
     Records.getAllDerivedDefinitions("Diagnostic");
-  
   for (unsigned i = 0, e = Diags.size(); i != e; ++i) {
     const Record *R = Diags[i];
     DefInit *DI = dynamic_cast<DefInit*>(R->getValueInit("Group"));
@@ -76,6 +75,13 @@ void ClangDiagGroupsEmitter::run(std::ostream &OS) {
     DiagsInGroup[DI->getDef()->getValueAsString("GroupName")].push_back(R);
   }
   
+  // Add all DiagGroup's to the DiagsInGroup list to make sure we pick up empty
+  // groups (these are warnings that GCC supports that clang never produces).
+  Diags = Records.getAllDerivedDefinitions("DiagGroup");
+  for (unsigned i = 0, e = Diags.size(); i != e; ++i) {
+    DiagsInGroup[Diags[i]->getValueAsString("GroupName")];
+  }
+  
   // Walk through the groups emitting an array for each diagnostic of the diags
   // that are mapped to.
   OS << "\n#ifdef GET_DIAG_ARRAYS\n";