Bart De Smet преди 7 години
родител
ревизия
7805451790
променени са 1 файла, в които са добавени 40 реда и са изтрити 43 реда
  1. 40 43
      Ix.NET/Source/System.Linq.Async/System/Threading/Tasks/AsyncEnumerableExtensions.cs

+ 40 - 43
Ix.NET/Source/System.Linq.Async/System/Threading/Tasks/AsyncEnumerableExtensions.cs

@@ -7,67 +7,64 @@ using System.Runtime.CompilerServices;
 
 namespace System.Threading.Tasks
 {
-    namespace System.Threading.Tasks
+    public static class AsyncEnumerableExtensions
     {
-        public static class AsyncEnumerableExtensions
+        public static ConfiguredAsyncEnumerable<T> ConfigureAwait<T>(this IAsyncEnumerable<T> enumerable, bool continueOnCapturedContext)
         {
-            public static ConfiguredAsyncEnumerable<T> ConfigureAwait<T>(this IAsyncEnumerable<T> enumerable, bool continueOnCapturedContext)
+            if (enumerable == null)
+                throw Error.ArgumentNull(nameof(enumerable));
+
+            return new ConfiguredAsyncEnumerable<T>(enumerable, continueOnCapturedContext);
+        }
+
+        // REVIEW: Explicit implementation of the interfaces allows for composition with other "modifier operators" such as WithCancellation.
+        //         We expect that the "await foreach" statement will bind to the public struct methods, thus avoiding boxing.
+
+        public readonly struct ConfiguredAsyncEnumerable<T> : IAsyncEnumerable<T>
+        {
+            private readonly IAsyncEnumerable<T> _enumerable;
+            private readonly bool _continueOnCapturedContext;
+
+            internal ConfiguredAsyncEnumerable(IAsyncEnumerable<T> enumerable, bool continueOnCapturedContext)
+            {
+                _enumerable = enumerable;
+                _continueOnCapturedContext = continueOnCapturedContext;
+            }
+
+            public ConfiguredAsyncEnumerator GetAsyncEnumerator(CancellationToken cancellationToken)
             {
-                if (enumerable == null)
-                    throw Error.ArgumentNull(nameof(enumerable));
+                cancellationToken.ThrowIfCancellationRequested(); // NB: [LDM-2018-11-28] Equivalent to async iterator behavior.
 
-                return new ConfiguredAsyncEnumerable<T>(enumerable, continueOnCapturedContext);
+                return new ConfiguredAsyncEnumerator(_enumerable.GetAsyncEnumerator(cancellationToken), _continueOnCapturedContext);
             }
 
-            // REVIEW: Explicit implementation of the interfaces allows for composition with other "modifier operators" such as WithCancellation.
-            //         We expect that the "await foreach" statement will bind to the public struct methods, thus avoiding boxing.
+            IAsyncEnumerator<T> IAsyncEnumerable<T>.GetAsyncEnumerator(CancellationToken cancellationToken) =>
+                GetAsyncEnumerator(cancellationToken);
 
-            public readonly struct ConfiguredAsyncEnumerable<T> : IAsyncEnumerable<T>
+            public readonly struct ConfiguredAsyncEnumerator : IAsyncEnumerator<T>
             {
-                private readonly IAsyncEnumerable<T> _enumerable;
+                private readonly IAsyncEnumerator<T> _enumerator;
                 private readonly bool _continueOnCapturedContext;
 
-                internal ConfiguredAsyncEnumerable(IAsyncEnumerable<T> enumerable, bool continueOnCapturedContext)
+                internal ConfiguredAsyncEnumerator(IAsyncEnumerator<T> enumerator, bool continueOnCapturedContext)
                 {
-                    _enumerable = enumerable;
+                    _enumerator = enumerator;
                     _continueOnCapturedContext = continueOnCapturedContext;
                 }
 
-                public ConfiguredAsyncEnumerator GetAsyncEnumerator(CancellationToken cancellationToken)
-                {
-                    cancellationToken.ThrowIfCancellationRequested(); // NB: [LDM-2018-11-28] Equivalent to async iterator behavior.
-
-                    return new ConfiguredAsyncEnumerator(_enumerable.GetAsyncEnumerator(cancellationToken), _continueOnCapturedContext);
-                }
+                public ConfiguredValueTaskAwaitable<bool> MoveNextAsync() =>
+                    _enumerator.MoveNextAsync().ConfigureAwait(_continueOnCapturedContext);
 
-                IAsyncEnumerator<T> IAsyncEnumerable<T>.GetAsyncEnumerator(CancellationToken cancellationToken) =>
-                    GetAsyncEnumerator(cancellationToken);
-
-                public readonly struct ConfiguredAsyncEnumerator : IAsyncEnumerator<T>
-                {
-                    private readonly IAsyncEnumerator<T> _enumerator;
-                    private readonly bool _continueOnCapturedContext;
+                public T Current => _enumerator.Current;
 
-                    internal ConfiguredAsyncEnumerator(IAsyncEnumerator<T> enumerator, bool continueOnCapturedContext)
-                    {
-                        _enumerator = enumerator;
-                        _continueOnCapturedContext = continueOnCapturedContext;
-                    }
+                public ConfiguredValueTaskAwaitable DisposeAsync() =>
+                    _enumerator.DisposeAsync().ConfigureAwait(_continueOnCapturedContext);
 
-                    public ConfiguredValueTaskAwaitable<bool> MoveNextAsync() =>
-                        _enumerator.MoveNextAsync().ConfigureAwait(_continueOnCapturedContext);
+                async ValueTask<bool> IAsyncEnumerator<T>.MoveNextAsync() =>
+                    await _enumerator.MoveNextAsync().ConfigureAwait(_continueOnCapturedContext);
 
-                    public T Current => _enumerator.Current;
-
-                    public ConfiguredValueTaskAwaitable DisposeAsync() =>
-                        _enumerator.DisposeAsync().ConfigureAwait(_continueOnCapturedContext);
-
-                    async ValueTask<bool> IAsyncEnumerator<T>.MoveNextAsync() =>
-                        await _enumerator.MoveNextAsync().ConfigureAwait(_continueOnCapturedContext);
-
-                    async ValueTask IAsyncDisposable.DisposeAsync() =>
-                        await _enumerator.DisposeAsync().ConfigureAwait(_continueOnCapturedContext);
-                }
+                async ValueTask IAsyncDisposable.DisposeAsync() =>
+                    await _enumerator.DisposeAsync().ConfigureAwait(_continueOnCapturedContext);
             }
         }
     }