Disallow multiple instances of PluginPriority.
authorMikhail Glushenkov <foldr@codedgers.com>
Sat, 17 Oct 2009 20:08:30 +0000 (20:08 +0000)
committerMikhail Glushenkov <foldr@codedgers.com>
Sat, 17 Oct 2009 20:08:30 +0000 (20:08 +0000)
Several instances of PluginPriority in a single file most probably signifies a
programming error.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@84350 91177308-0d34-0410-b5e6-96231b3b80d8

test/LLVMC/MultiplePluginPriorities.td [new file with mode: 0644]
utils/TableGen/LLVMCConfigurationEmitter.cpp

diff --git a/test/LLVMC/MultiplePluginPriorities.td b/test/LLVMC/MultiplePluginPriorities.td
new file mode 100644 (file)
index 0000000..721b7cc
--- /dev/null
@@ -0,0 +1,10 @@
+// Check that multiple plugin priorities are not allowed.
+// RUN: ignore tblgen -I %p/../../include --gen-llvmc %s |& grep "More than one 'PluginPriority' instance found"
+
+include "llvm/CompilerDriver/Common.td"
+
+def Graph : CompilationGraph<[]>;
+
+def Priority1 : PluginPriority<1>;
+
+def Priority2 : PluginPriority<2>;
index 06afaf73a02e96aea105778f635dfc23841fcf12..6dfd1b362d5c8476d20895e26e0492efd8d53705 100644 (file)
@@ -775,11 +775,17 @@ void FillInEdgeVector(RecordVector::const_iterator B,
 /// CalculatePriority - Calculate the priority of this plugin.
 int CalculatePriority(RecordVector::const_iterator B,
                       RecordVector::const_iterator E) {
-  int total = 0;
-  for (; B!=E; ++B) {
-    total += static_cast<int>((*B)->getValueAsInt("priority"));
+  int priority = 0;
+
+  if (B != E) {
+    priority  = static_cast<int>((*B)->getValueAsInt("priority"));
+
+    if (++B != E)
+      throw std::string("More than one 'PluginPriority' instance found: "
+                        "most probably an error!");
   }
-  return total;
+
+  return priority;
 }
 
 /// NotInGraph - Helper function object for FilterNotInGraph.