Merge pull request #901 from Blewzman/FixAggregateExceptionGetBaseException
[mono.git] / mcs / class / corlib / System.Runtime.CompilerServices / AsyncTaskMethodBuilder_T.cs
index 96f6dc68ab0fd9ef994ce80b91fe41a1ef40602e..9d539dfc42dc4f5bc56c71e5d94b8371432b5298 100644 (file)
@@ -69,14 +69,14 @@ namespace System.Runtime.CompilerServices
                
                public static AsyncTaskMethodBuilder<TResult> Create ()
                {
-                       var task = new Task<TResult> (TaskActionInvoker.Empty, null, CancellationToken.None, TaskCreationOptions.None, null);
+                       var task = new Task<TResult> (TaskActionInvoker.Promise, null, CancellationToken.None, TaskCreationOptions.None, null);
                        task.SetupScheduler (TaskScheduler.Current);
                        return new AsyncTaskMethodBuilder<TResult> (task);
                }
 
                public void SetException (Exception exception)
                {
-                       if (Task.TrySetException (new AggregateException (exception), exception is OperationCanceledException))
+                       if (Task.TrySetException (new AggregateException (exception), exception is OperationCanceledException, true))
                                return;
 
                        throw new InvalidOperationException ("The task has already completed");