summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>2003-03-21 07:08:02 +0000
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>2003-03-21 07:08:02 +0000
commitec10b85339d1865c948a33866cc759635330c062 (patch)
tree27e2366b724a6c36b540bd88f4ceccdcc1330023
parentf5083c1bb992083bd438841be220b94c3b35ad1f (diff)
downloadppe42-gcc-ec10b85339d1865c948a33866cc759635330c062.tar.gz
ppe42-gcc-ec10b85339d1865c948a33866cc759635330c062.zip
PR c++/7050
* expr.c (store_expr): Don't attempt to store void-typed trees, just evaluate them for side effects. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@64646 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/testsuite/g++.dg/eh/cond1.C64
1 files changed, 64 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/eh/cond1.C b/gcc/testsuite/g++.dg/eh/cond1.C
new file mode 100644
index 00000000000..4f494267e4b
--- /dev/null
+++ b/gcc/testsuite/g++.dg/eh/cond1.C
@@ -0,0 +1,64 @@
+// PR c++/7050
+// { dg-do run }
+
+extern "C" void abort(void);
+
+#define CI(stmt) try { stmt; abort(); } catch (int) { }
+
+struct has_destructor
+{
+ ~has_destructor() { }
+};
+
+struct no_destructor
+{
+};
+
+int PI(int& i) { return i++; }
+
+int main(int argc, char *argv[])
+{
+ (argc+1 ? has_destructor() : throw 0);
+ CI((argc+1 ? throw 0 : has_destructor()));
+ CI((0 ? has_destructor() : throw 0));
+ CI((1 ? throw 0 : has_destructor()));
+ (0 ? throw 0 : has_destructor());
+ (1 ? has_destructor() : throw 0);
+
+ (argc+1 ? no_destructor() : throw 0);
+ CI((argc+1 ? throw 0 : no_destructor()));
+ CI((0 ? no_destructor() : throw 0));
+ CI((1 ? throw 0 : no_destructor()));
+ (0 ? throw 0 : no_destructor());
+ (1 ? no_destructor() : throw 0);
+
+ int i = 1;
+ CI(throw PI(i));
+ if (i != 2) abort();
+
+ (1 ? 0 : throw PI(i));
+ if (i != 2) abort();
+
+ CI(0 ? 0 : throw PI(i));
+ if (i != 3) abort();
+
+ CI(0 ? has_destructor() : throw PI(i));
+ if (i != 4) abort();
+ (argc+1 ? has_destructor() : throw PI(i));
+ if (i != 4) abort();
+
+ i = 1;
+ CI(throw i++);
+ if (i != 2) abort();
+
+ (1 ? 0 : throw i++);
+ if (i != 2) abort();
+
+ CI(0 ? 0 : throw i++);
+ if (i != 3) abort();
+
+ CI(0 ? has_destructor() : throw i++);
+ if (i != 4) abort();
+ (argc+1 ? has_destructor() : throw i++);
+ if (i != 4) abort();
+}
OpenPOWER on IntegriCloud