re PR c++/26291 (Invalid ellipsis in operator not diagnosed)
authorVolker Reichelt <reichelt@gcc.gnu.org>
Wed, 22 Feb 2006 17:22:08 +0000 (17:22 +0000)
committerVolker Reichelt <reichelt@gcc.gnu.org>
Wed, 22 Feb 2006 17:22:08 +0000 (17:22 +0000)
PR c++/26291
* decl.c (grok_op_properties): Check for ellipsis in arguments of
        operators.

* g++.dg/other/ellipsis1.C: New test.
* g++.dg/parse/operator4.C: Adjust error marker.

From-SVN: r111367

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/other/ellipsis1.C [new file with mode: 0644]
gcc/testsuite/g++.dg/parse/operator4.C

index 6a1e2f1d461072c742e734da12ebe66e6f0a5c3d..c888a09acc24fbe5a0147aa6c0222bd42597d072 100644 (file)
@@ -1,6 +1,13 @@
-2006-02-20 Rafael Ávila de Espíndola <rafael.espindola@gmail.com>
-       * Make-lang.in (C++): Remove
-       (.PHONY): Remove C++
+2006-02-22  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
+
+       PR c++/26291
+       * decl.c (grok_op_properties): Check for ellipsis in arguments of
+        operators.
+
+2006-02-20  Rafael Ávila de Espíndola  <rafael.espindola@gmail.com>
+
+       * Make-lang.in (C++): Remove.
+       (.PHONY): Remove C++.
 
 2006-02-18  Mark Mitchell  <mark@codesourcery.com>
 
index 35dc38c0a45537bc4eb9b8d3f1a80bcedbf01a54..c803a84bac1a0bd5b68f2bc797f9fdc558293072 100644 (file)
@@ -8828,13 +8828,15 @@ grok_op_properties (tree decl, bool complain)
   tree name = DECL_NAME (decl);
   enum tree_code operator_code;
   int arity;
+  bool ellipsis_p;
   tree class_type;
 
-  /* Count the number of arguments.  */
+  /* Count the number of arguments and check for ellipsis.  */
   for (argtype = argtypes, arity = 0;
        argtype && argtype != void_list_node;
        argtype = TREE_CHAIN (argtype))
     ++arity;
+  ellipsis_p = !argtype;
 
   class_type = DECL_CONTEXT (decl);
   if (class_type && !CLASS_TYPE_P (class_type))
@@ -9000,11 +9002,14 @@ grok_op_properties (tree decl, bool complain)
                     "conversion operator",
                     ref ? "a reference to " : "", what);
        }
+
       if (operator_code == COND_EXPR)
        {
          /* 13.4.0.3 */
          error ("ISO C++ prohibits overloading operator ?:");
        }
+      else if (ellipsis_p)
+       error ("%qD must not have variable number of arguments", decl);
       else if (ambi_op_p (operator_code))
        {
          if (arity == 1)
index 6d36553f9f609e3ab85187cd4078f1e50df96b1f..951bc113265c423097916b6a22e11137b5c6fb79 100644 (file)
@@ -1,3 +1,9 @@
+2006-02-22  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
+
+       PR c++/26291
+       * g++.dg/other/ellipsis1.C: New test.
+       * g++.dg/parse/operator4.C: Adjust error marker.
+
 2006-02-22  H.J. Lu  <hongjiu.lu@intel.com>
 
        PR target/25603
diff --git a/gcc/testsuite/g++.dg/other/ellipsis1.C b/gcc/testsuite/g++.dg/other/ellipsis1.C
new file mode 100644 (file)
index 0000000..d2501ca
--- /dev/null
@@ -0,0 +1,12 @@
+// PR c++/26291
+// { dg-do compile }
+
+struct A
+{
+    A& operator= (A,...);  // { dg-error "variable number of arguments" }
+    A operator+ (...);     // { dg-error "variable number of arguments" }
+    operator int(...);     // { dg-error "variable number of arguments" }
+    int operator() (...);
+};
+
+A operator- (A,...);       // { dg-error "variable number of arguments" }
index 9395ccdd1b231b8d4538718a1c2a023b95f346dd..054ddc8354f2ec210d79263589aee7b60d466599 100644 (file)
@@ -1 +1 @@
-int operator *(int, ...); // { dg-error "class" }
+int operator *(int, ...); // { dg-error "class|variable number of arguments" }