X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmini%2Fexceptions.cs;h=1e3ded9587a7d63ff7bdf25ad5024fc446fe7cb4;hb=56247cecbdce6dc3a14228541bbb7515634f099b;hp=98c6046e61a5cdea5dab273ee1b289d63c26a7b5;hpb=687bbf2f71c14dd7c0740bcbd7c3b6f56ca39594;p=mono.git diff --git a/mono/mini/exceptions.cs b/mono/mini/exceptions.cs index 98c6046e61a..1e3ded9587a 100644 --- a/mono/mini/exceptions.cs +++ b/mono/mini/exceptions.cs @@ -1427,6 +1427,7 @@ class Tests return 0; } + [Category ("!WASM")] // reported as https://github.com/kripken/emscripten/issues/5603 public static int test_0_simple_double_casts () { double d = 0xffffffff; @@ -1462,7 +1463,6 @@ class Tests return 0; } - [Category ("NaClDisable")] public static int test_0_div_zero () { int d = 1; int q = 0; @@ -1633,7 +1633,6 @@ class Tests return 0; } - [Category ("NaClDisable")] public static int test_0_long_div_zero () { long d = 1; long q = 0; @@ -2845,6 +2844,95 @@ class Tests } return 0; } + + public class MyException : Exception { + public int marker = 0; + public string res = ""; + + public MyException (String res) { + this.res = res; + } + + public bool FilterWithoutState () { + return this.marker == 0x666; + } + + public bool FilterWithState () { + bool ret = this.marker == 0x566; + this.marker += 0x100; + return ret; + } + + public bool FilterWithStringState () { + bool ret = this.marker == 0x777; + this.res = "fromFilter_" + this.res; + return ret; + } + } + + [Category ("!BITCODE")] + public static int test_1_basic_filter_catch () { + try { + MyException e = new MyException (""); + e.marker = 0x1337; + throw e; + } catch (MyException ex) when (ex.marker == 0x1337) { + return 1; + } + return 0; + } + + [Category ("!BITCODE")] + public static int test_1234_complicated_filter_catch () { + string res = "init"; + try { + MyException e = new MyException (res); + e.marker = 0x566; + try { + try { + throw e; + } catch (MyException ex) when (ex.FilterWithoutState ()) { + res = "WRONG_" + res; + } finally { + e.marker = 0x777; + res = "innerFinally_" + res; + } + } catch (MyException ex) when (ex.FilterWithState ()) { + res = "2ndcatch_" + res; + } + // "2ndcatch_innerFinally_init" + // Console.WriteLine ("res1: " + res); + e.res = res; + throw e; + } catch (MyException ex) when (ex.FilterWithStringState ()) { + res = "fwos_" + ex.res; + } finally { + res = "outerFinally_" + res; + } + // Console.WriteLine ("res2: " + res); + return "outerFinally_fwos_fromFilter_2ndcatch_innerFinally_init" == res ? 1234 : 0; + } + + public struct FooStruct + { + public long Part1 { get; } + public long Part2 { get; } + + public byte Part3 { get; } + } + + [MethodImpl( MethodImplOptions.NoInlining )] + private static bool ExceptionFilter( byte x, FooStruct item ) => true; + + [Category ("!BITCODE")] + public static int test_0_filter_caller_area () { + try { + throw new Exception(); + } + catch (Exception) when (ExceptionFilter (default(byte), default (FooStruct))) { + } + return 0; + } } #if !__MOBILE__