summaryrefslogtreecommitdiff
path: root/trunk/Examples/test-suite/csharp/exception_order_runme.cs
diff options
context:
space:
mode:
authorWilliam S Fulton <wsf@fultondesigns.co.uk>2010-06-02 20:53:17 +0000
committerWilliam S Fulton <wsf@fultondesigns.co.uk>2010-06-02 20:53:17 +0000
commit2824b0cbb66e715490e1ef13250bd675d87b32d9 (patch)
treec3bc8d54c6d73f2b7ce08cac34172dbc9f5e5b95 /trunk/Examples/test-suite/csharp/exception_order_runme.cs
parent289cfef4b4766ff266f3b1bdda8ca3a952e5a047 (diff)
downloadswig-2.0.0.tar.gz
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/tags/rel-2.0.0@12089 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'trunk/Examples/test-suite/csharp/exception_order_runme.cs')
-rw-r--r--trunk/Examples/test-suite/csharp/exception_order_runme.cs48
1 files changed, 48 insertions, 0 deletions
diff --git a/trunk/Examples/test-suite/csharp/exception_order_runme.cs b/trunk/Examples/test-suite/csharp/exception_order_runme.cs
new file mode 100644
index 000000000..16b32983f
--- /dev/null
+++ b/trunk/Examples/test-suite/csharp/exception_order_runme.cs
@@ -0,0 +1,48 @@
+using System;
+using exception_orderNamespace;
+
+public class runme {
+ static void Main() {
+ A a = new A();
+
+ try {
+ a.foo();
+ throw new Exception("missed exception");
+ } catch (ApplicationException e) {
+ if (e.Message != "C++ E1 exception thrown")
+ throw new ApplicationException("bad exception order: " + e.Message);
+ }
+
+ try {
+ a.bar();
+ throw new Exception("missed exception");
+ } catch (ApplicationException e) {
+ if (e.Message != "C++ E2 exception thrown")
+ throw new ApplicationException("bad exception order: " + e.Message);
+ }
+
+ try {
+ a.foobar();
+ throw new Exception("missed exception");
+ } catch (ApplicationException e) {
+ if (e.Message != "postcatch unknown")
+ throw new ApplicationException("bad exception order: " + e.Message);
+ }
+
+ try {
+ a.barfoo(1);
+ throw new Exception("missed exception");
+ } catch (ApplicationException e) {
+ if (e.Message != "C++ E1 exception thrown")
+ throw new ApplicationException("bad exception order: " + e.Message);
+ }
+
+ try {
+ a.barfoo(2);
+ throw new Exception("missed exception");
+ } catch (ApplicationException e) {
+ if (e.Message != "C++ E2 * exception thrown")
+ throw new ApplicationException("bad exception order: " + e.Message);
+ }
+ }
+}