diff options
author | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 13:02:25 -0700 |
---|---|---|
committer | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 16:13:41 -0700 |
commit | 17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch) | |
tree | b5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Platform.WinRT/TaskExtensions.cs | |
download | xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2 xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip |
Initial import
Diffstat (limited to 'Xamarin.Forms.Platform.WinRT/TaskExtensions.cs')
-rw-r--r-- | Xamarin.Forms.Platform.WinRT/TaskExtensions.cs | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/Xamarin.Forms.Platform.WinRT/TaskExtensions.cs b/Xamarin.Forms.Platform.WinRT/TaskExtensions.cs new file mode 100644 index 00000000..332e8a64 --- /dev/null +++ b/Xamarin.Forms.Platform.WinRT/TaskExtensions.cs @@ -0,0 +1,40 @@ +using System; +using System.Threading; +using System.Threading.Tasks; +using Windows.Foundation; + +#if WINDOWS_UWP + +namespace Xamarin.Forms.Platform.UWP +#else + +namespace Xamarin.Forms.Platform.WinRT +#endif +{ + internal static class TaskExtensions + { + public static void WatchForError(this IAsyncAction self) + { + self.AsTask().WatchForError(); + } + + public static void WatchForError<T>(this IAsyncOperation<T> self) + { + self.AsTask().WatchForError(); + } + + public static void WatchForError(this Task self) + { + SynchronizationContext context = SynchronizationContext.Current; + if (context == null) + return; + + self.ContinueWith(t => + { + Exception exception = t.Exception.InnerExceptions.Count > 1 ? t.Exception : t.Exception.InnerException; + + context.Post(e => { throw (Exception)e; }, exception); + }, CancellationToken.None, TaskContinuationOptions.OnlyOnFaulted, TaskScheduler.Default); + } + } +}
\ No newline at end of file |