aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C')
-rw-r--r--gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C36
1 files changed, 36 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C b/gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C
new file mode 100644
index 00000000000..df7e641fe5f
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.bugs/900220_01.C
@@ -0,0 +1,36 @@
+// g++ 1.36.1 bug 900220_01
+
+// Ref: 12.8
+
+// Section 12.8 says:
+
+// "That is, X::operator=() will be generated only if no assignment
+// operation is explicitly declared and an object of class X is actually
+// assigned an object of class X (or an object of a class derived from X)
+// or if the address of X::operator= is taken.
+
+// g++ does not allow you to take the address of an implicitly generated
+// operator=
+
+// keywords: operator=, implicit copy operator, operator&
+
+struct struct0 {
+ int data_member;
+};
+
+typedef struct0& (struct0::*member_func_t) (const struct0&);
+
+member_func_t member_func;
+
+void global_function_0 (member_func_t member_f)
+{ // gets bogus error - ref from below
+}
+
+void global_function_1 ()
+{
+ member_func = &struct0::operator=; // gets bogus error
+
+ global_function_0 (&struct0::operator=); // gets bogus error
+}
+
+int main () { return 0; }