aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@gcc.gnu.org>2004-06-17 23:05:15 -0400
committerJason Merrill <jason@gcc.gnu.org>2004-06-17 23:05:15 -0400
commiteb52a1638d528ce0c8df43d1a870da1474c2428f (patch)
tree76906e2848d2f882b47b0a0c4087d866e258cd95 /gcc
parent70c18d9772113dcf36a386f7950bd65bf67a8b23 (diff)
downloadgcc-eb52a1638d528ce0c8df43d1a870da1474c2428f.zip
gcc-eb52a1638d528ce0c8df43d1a870da1474c2428f.tar.gz
gcc-eb52a1638d528ce0c8df43d1a870da1474c2428f.tar.bz2
new test
From-SVN: r83337
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/g++.dg/ext/stmtexpr2.C39
1 files changed, 39 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/ext/stmtexpr2.C b/gcc/testsuite/g++.dg/ext/stmtexpr2.C
new file mode 100644
index 0000000..7294577
--- /dev/null
+++ b/gcc/testsuite/g++.dg/ext/stmtexpr2.C
@@ -0,0 +1,39 @@
+// { dg-do run }
+// { dg-options "" }
+
+extern "C" int printf (char const *, ...);
+extern "C" void abort ();
+
+static unsigned int expected[] = {
+ 11, 10, 21, 110, 111, 121
+};
+static unsigned int pointer = 0;
+
+static void Check (unsigned t, unsigned i, void const *ptr, char const *name)
+{
+ printf ("%d %d %p %s\n", t, i, ptr, name);
+
+ if (pointer > sizeof(expected)/sizeof(expected[0]))
+ abort ();
+ if (t + i != expected[pointer++])
+ abort ();
+}
+
+struct A
+{
+ int I;
+
+ A (int i) : I(i) { Check (0, I, this, __PRETTY_FUNCTION__); }
+ ~A () { Check (100, I, this, __PRETTY_FUNCTION__); }
+ A (A const &a) : I(a.I) { Check (200, I, this, __PRETTY_FUNCTION__); }
+ A &operator= (A const &a)
+ { I = a.I; Check (300, I, this, __PRETTY_FUNCTION__); return *this; }
+ void Foo () const { Check (400, I, this, __PRETTY_FUNCTION__); }
+ A operator+ (A const &a) const
+ { return A(I + a.I); }
+};
+
+int main ()
+{
+ ({ A(10) + A(11); });
+}