TaskResult.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. namespace Caliburn.Micro.Core {
  2. using System;
  3. using System.Threading.Tasks;
  4. /// <summary>
  5. /// A couroutine that encapsulates an <see cref="System.Threading.Tasks.Task"/>.
  6. /// </summary>
  7. public class TaskResult : IResult {
  8. readonly Task innerTask;
  9. /// <summary>
  10. /// Initializes a new instance of the <see cref="TaskResult"/> class.
  11. /// </summary>
  12. /// <param name="task">The task.</param>
  13. public TaskResult(Task task) {
  14. innerTask = task;
  15. }
  16. /// <summary>
  17. /// Executes the result using the specified context.
  18. /// </summary>
  19. /// <param name="context">The context.</param>
  20. public void Execute(CoroutineExecutionContext context) {
  21. if (innerTask.IsCompleted)
  22. OnCompleted(innerTask);
  23. else
  24. innerTask.ContinueWith(OnCompleted,
  25. System.Threading.SynchronizationContext.Current != null
  26. ? TaskScheduler.FromCurrentSynchronizationContext()
  27. : TaskScheduler.Current);
  28. }
  29. /// <summary>
  30. /// Called when the asynchronous task has completed.
  31. /// </summary>
  32. /// <param name="task">The completed task.</param>
  33. protected virtual void OnCompleted(Task task) {
  34. Completed(this, new ResultCompletionEventArgs {WasCancelled = task.IsCanceled, Error = task.Exception});
  35. }
  36. /// <summary>
  37. /// Occurs when execution has completed.
  38. /// </summary>
  39. public event EventHandler<ResultCompletionEventArgs> Completed = delegate { };
  40. }
  41. /// <summary>
  42. /// A couroutine that encapsulates an <see cref="System.Threading.Tasks.Task&lt;TResult&gt;"/>.
  43. /// </summary>
  44. /// <typeparam name="TResult">The type of the result.</typeparam>
  45. public class TaskResult<TResult> : TaskResult, IResult<TResult> {
  46. /// <summary>
  47. /// Initializes a new instance of the <see cref="TaskResult{TResult}"/> class.
  48. /// </summary>
  49. /// <param name="task">The task.</param>
  50. public TaskResult(Task<TResult> task)
  51. : base(task) {
  52. }
  53. /// <summary>
  54. /// Gets the result of the asynchronous operation.
  55. /// </summary>
  56. public TResult Result { get; private set; }
  57. /// <summary>
  58. /// Called when the asynchronous task has completed.
  59. /// </summary>
  60. /// <param name="task">The completed task.</param>
  61. protected override void OnCompleted(Task task) {
  62. if (!task.IsFaulted && !task.IsCanceled)
  63. Result = ((Task<TResult>) task).Result;
  64. base.OnCompleted(task);
  65. }
  66. }
  67. }