aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C')
-rw-r--r--gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C42
1 files changed, 42 insertions, 0 deletions
diff --git a/gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C b/gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C
new file mode 100644
index 000000000..d0625c4b4
--- /dev/null
+++ b/gcc-4.8/gcc/testsuite/g++.old-deja/g++.bugs/900428_03.C
@@ -0,0 +1,42 @@
+// { dg-do assemble }
+// g++ 1.37.1 bug 900428_03
+
+// g++ fails to detect cases where a constructor for a derived class invokes
+// (either explicitly or implicitly) a private constructor for a base class.
+
+// cfront 2.0 passes this test.
+
+// keywords: inheritance, private, accessability, constructors
+
+struct struct_0 {
+ int struct_0_data_member;
+
+private:
+ struct_0 (int, int);
+public:
+ struct_0 (int);
+};
+
+struct_0::struct_0 (int i) { }
+struct_0::struct_0 (int, int) { } // { dg-error "is private" }
+
+struct struct_1 : public struct_0 {
+
+ struct_1 ();
+};
+
+struct_1::struct_1 () : struct_0 (8,9) // { dg-error "within this context" }
+{
+}
+
+struct struct_2 {
+ struct_0 struct_2_data_member;
+
+ struct_2 ();
+};
+
+struct_2::struct_2 () : struct_2_data_member (8,9) // { dg-error "within this context" }
+{
+}
+
+int main () { return 0; }