summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.jason/synth10.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.jason/synth10.C')
-rw-r--r--gcc/testsuite/g++.old-deja/g++.jason/synth10.C52
1 files changed, 52 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.jason/synth10.C b/gcc/testsuite/g++.old-deja/g++.jason/synth10.C
new file mode 100644
index 000000000..f6181dc7c
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.jason/synth10.C
@@ -0,0 +1,52 @@
+// { dg-do assemble }
+// { dg-options "-O" }
+// Bug: Synthesizing methods for the nested class screwed up current_class_decl
+// for the outer class.
+
+class A;
+class AH
+{
+ public:
+ AH ( A * p = 0 );
+ AH ( const AH & from )
+ : pointer( from.pointer ) { inc(); }
+ ~ AH () { dec(); }
+ private:
+ A * pointer;
+ void inc() const;
+ void dec() const;
+};
+
+class A
+{
+ protected:
+ struct AttrTable
+ {
+ struct Row
+ {
+ };
+ };
+
+ public:
+
+ class Attributes
+ {
+ public:
+ class iterator
+ {
+ public:
+ iterator() : mo(0), attr(0) {}
+ iterator& operator++() { ++attr; return *this; }
+ iterator operator++(int)
+ { iterator tmp = *this; ++*this; return tmp; }
+
+ private:
+ AH mo;
+ const AttrTable::Row* attr;
+ };
+
+ Attributes(AH mo)
+ : mo(mo) {}
+ AH mo;
+ };
+};