OrderBy.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. // Licensed to the .NET Foundation under one or more agreements.
  2. // The .NET Foundation licenses this file to you under the Apache 2.0 License.
  3. // See the LICENSE file in the project root for more information.
  4. using System.Collections.Generic;
  5. using System.Threading;
  6. using System.Threading.Tasks;
  7. namespace System.Linq
  8. {
  9. public static partial class AsyncEnumerable
  10. {
  11. public static IOrderedAsyncEnumerable<TSource> OrderBy<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector)
  12. {
  13. if (source == null)
  14. throw Error.ArgumentNull(nameof(source));
  15. if (keySelector == null)
  16. throw Error.ArgumentNull(nameof(keySelector));
  17. return new OrderedAsyncEnumerable<TSource, TKey>(source, keySelector, comparer: null, descending: false, parent: null);
  18. }
  19. public static IOrderedAsyncEnumerable<TSource> OrderBy<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector)
  20. {
  21. if (source == null)
  22. throw Error.ArgumentNull(nameof(source));
  23. if (keySelector == null)
  24. throw Error.ArgumentNull(nameof(keySelector));
  25. return new OrderedAsyncEnumerableWithTask<TSource, TKey>(source, keySelector, comparer: null, descending: false, parent: null);
  26. }
  27. public static IOrderedAsyncEnumerable<TSource> OrderBy<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector, IComparer<TKey> comparer)
  28. {
  29. if (source == null)
  30. throw Error.ArgumentNull(nameof(source));
  31. if (keySelector == null)
  32. throw Error.ArgumentNull(nameof(keySelector));
  33. return new OrderedAsyncEnumerable<TSource, TKey>(source, keySelector, comparer, descending: false, parent: null);
  34. }
  35. public static IOrderedAsyncEnumerable<TSource> OrderBy<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  36. {
  37. if (source == null)
  38. throw Error.ArgumentNull(nameof(source));
  39. if (keySelector == null)
  40. throw Error.ArgumentNull(nameof(keySelector));
  41. return new OrderedAsyncEnumerableWithTask<TSource, TKey>(source, keySelector, comparer, descending: false, parent: null);
  42. }
  43. #if !NO_DEEP_CANCELLATION
  44. public static IOrderedAsyncEnumerable<TSource> OrderBy<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  45. {
  46. if (source == null)
  47. throw Error.ArgumentNull(nameof(source));
  48. if (keySelector == null)
  49. throw Error.ArgumentNull(nameof(keySelector));
  50. return new OrderedAsyncEnumerableWithTaskAndCancellation<TSource, TKey>(source, keySelector, comparer, descending: false, parent: null);
  51. }
  52. #endif
  53. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector)
  54. {
  55. if (source == null)
  56. throw Error.ArgumentNull(nameof(source));
  57. if (keySelector == null)
  58. throw Error.ArgumentNull(nameof(keySelector));
  59. return new OrderedAsyncEnumerable<TSource, TKey>(source, keySelector, comparer: null, descending: true, parent: null);
  60. }
  61. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector)
  62. {
  63. if (source == null)
  64. throw Error.ArgumentNull(nameof(source));
  65. if (keySelector == null)
  66. throw Error.ArgumentNull(nameof(keySelector));
  67. return new OrderedAsyncEnumerableWithTask<TSource, TKey>(source, keySelector, comparer: null, descending: true, parent: null);
  68. }
  69. #if !NO_DEEP_CANCELLATION
  70. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector)
  71. {
  72. if (source == null)
  73. throw Error.ArgumentNull(nameof(source));
  74. if (keySelector == null)
  75. throw Error.ArgumentNull(nameof(keySelector));
  76. return new OrderedAsyncEnumerableWithTaskAndCancellation<TSource, TKey>(source, keySelector, comparer: null, descending: true, parent: null);
  77. }
  78. #endif
  79. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector, IComparer<TKey> comparer)
  80. {
  81. if (source == null)
  82. throw Error.ArgumentNull(nameof(source));
  83. if (keySelector == null)
  84. throw Error.ArgumentNull(nameof(keySelector));
  85. return new OrderedAsyncEnumerable<TSource, TKey>(source, keySelector, comparer, descending: true, parent: null);
  86. }
  87. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  88. {
  89. if (source == null)
  90. throw Error.ArgumentNull(nameof(source));
  91. if (keySelector == null)
  92. throw Error.ArgumentNull(nameof(keySelector));
  93. return new OrderedAsyncEnumerableWithTask<TSource, TKey>(source, keySelector, comparer, descending: true, parent: null);
  94. }
  95. #if !NO_DEEP_CANCELLATION
  96. public static IOrderedAsyncEnumerable<TSource> OrderByDescending<TSource, TKey>(this IAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  97. {
  98. if (source == null)
  99. throw Error.ArgumentNull(nameof(source));
  100. if (keySelector == null)
  101. throw Error.ArgumentNull(nameof(keySelector));
  102. return new OrderedAsyncEnumerableWithTaskAndCancellation<TSource, TKey>(source, keySelector, comparer, descending: true, parent: null);
  103. }
  104. #endif
  105. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector)
  106. {
  107. if (source == null)
  108. throw Error.ArgumentNull(nameof(source));
  109. if (keySelector == null)
  110. throw Error.ArgumentNull(nameof(keySelector));
  111. return source.CreateOrderedEnumerable(keySelector, comparer: null, descending: false);
  112. }
  113. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector)
  114. {
  115. if (source == null)
  116. throw Error.ArgumentNull(nameof(source));
  117. if (keySelector == null)
  118. throw Error.ArgumentNull(nameof(keySelector));
  119. return source.CreateOrderedEnumerable(keySelector, comparer: default(IComparer<TKey>), descending: false);
  120. }
  121. #if !NO_DEEP_CANCELLATION
  122. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector)
  123. {
  124. if (source == null)
  125. throw Error.ArgumentNull(nameof(source));
  126. if (keySelector == null)
  127. throw Error.ArgumentNull(nameof(keySelector));
  128. return source.CreateOrderedEnumerable(keySelector, comparer: null, descending: false);
  129. }
  130. #endif
  131. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector, IComparer<TKey> comparer)
  132. {
  133. if (source == null)
  134. throw Error.ArgumentNull(nameof(source));
  135. if (keySelector == null)
  136. throw Error.ArgumentNull(nameof(keySelector));
  137. return source.CreateOrderedEnumerable(keySelector, comparer, descending: false);
  138. }
  139. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  140. {
  141. if (source == null)
  142. throw Error.ArgumentNull(nameof(source));
  143. if (keySelector == null)
  144. throw Error.ArgumentNull(nameof(keySelector));
  145. return source.CreateOrderedEnumerable(keySelector, comparer, descending: false);
  146. }
  147. #if !NO_DEEP_CANCELLATION
  148. public static IOrderedAsyncEnumerable<TSource> ThenBy<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  149. {
  150. if (source == null)
  151. throw Error.ArgumentNull(nameof(source));
  152. if (keySelector == null)
  153. throw Error.ArgumentNull(nameof(keySelector));
  154. return source.CreateOrderedEnumerable(keySelector, comparer, descending: false);
  155. }
  156. #endif
  157. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector)
  158. {
  159. if (source == null)
  160. throw Error.ArgumentNull(nameof(source));
  161. if (keySelector == null)
  162. throw Error.ArgumentNull(nameof(keySelector));
  163. return source.CreateOrderedEnumerable(keySelector, comparer: null, descending: true);
  164. }
  165. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector)
  166. {
  167. if (source == null)
  168. throw Error.ArgumentNull(nameof(source));
  169. if (keySelector == null)
  170. throw Error.ArgumentNull(nameof(keySelector));
  171. return source.CreateOrderedEnumerable(keySelector, comparer: default(IComparer<TKey>), descending: true);
  172. }
  173. #if !NO_DEEP_CANCELLATION
  174. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector)
  175. {
  176. if (source == null)
  177. throw Error.ArgumentNull(nameof(source));
  178. if (keySelector == null)
  179. throw Error.ArgumentNull(nameof(keySelector));
  180. return source.CreateOrderedEnumerable(keySelector, comparer: null, descending: true);
  181. }
  182. #endif
  183. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, TKey> keySelector, IComparer<TKey> comparer)
  184. {
  185. if (source == null)
  186. throw Error.ArgumentNull(nameof(source));
  187. if (keySelector == null)
  188. throw Error.ArgumentNull(nameof(keySelector));
  189. return source.CreateOrderedEnumerable(keySelector, comparer, descending: true);
  190. }
  191. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  192. {
  193. if (source == null)
  194. throw Error.ArgumentNull(nameof(source));
  195. if (keySelector == null)
  196. throw Error.ArgumentNull(nameof(keySelector));
  197. return source.CreateOrderedEnumerable(keySelector, comparer, descending: true);
  198. }
  199. #if !NO_DEEP_CANCELLATION
  200. public static IOrderedAsyncEnumerable<TSource> ThenByDescending<TSource, TKey>(this IOrderedAsyncEnumerable<TSource> source, Func<TSource, CancellationToken, ValueTask<TKey>> keySelector, IComparer<TKey> comparer)
  201. {
  202. if (source == null)
  203. throw Error.ArgumentNull(nameof(source));
  204. if (keySelector == null)
  205. throw Error.ArgumentNull(nameof(keySelector));
  206. return source.CreateOrderedEnumerable(keySelector, comparer, descending: true);
  207. }
  208. #endif
  209. }
  210. }