diff options
| author | Bond_009 <bond.009@outlook.com> | 2021-01-24 11:43:05 +0100 |
|---|---|---|
| committer | Bond_009 <bond.009@outlook.com> | 2021-01-24 11:43:05 +0100 |
| commit | d24e7f60c754620f88faa294af5bf0309b59c785 (patch) | |
| tree | 0efa874d3075ec012fc63ff8c301e58c9012bdb6 /Jellyfin.Api/Helpers/RequestHelpers.cs | |
| parent | b4d04f9ca5345c87d44993fbbb9e211c1dbf2dcd (diff) | |
Fix GetOrderBy and add tests
Diffstat (limited to 'Jellyfin.Api/Helpers/RequestHelpers.cs')
| -rw-r--r-- | Jellyfin.Api/Helpers/RequestHelpers.cs | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/Jellyfin.Api/Helpers/RequestHelpers.cs b/Jellyfin.Api/Helpers/RequestHelpers.cs index 056ad83da..59cb8ea2c 100644 --- a/Jellyfin.Api/Helpers/RequestHelpers.cs +++ b/Jellyfin.Api/Helpers/RequestHelpers.cs @@ -25,22 +25,25 @@ namespace Jellyfin.Api.Helpers /// <param name="sortBy">Sort By. Comma delimited string.</param> /// <param name="requestedSortOrder">Sort Order. Comma delimited string.</param> /// <returns>Order By.</returns> - public static ValueTuple<string, SortOrder>[] GetOrderBy(IReadOnlyList<string> sortBy, IReadOnlyList<SortOrder> requestedSortOrder) + public static (string, SortOrder)[] GetOrderBy(IReadOnlyList<string> sortBy, IReadOnlyList<SortOrder> requestedSortOrder) { if (sortBy.Count == 0) { return Array.Empty<ValueTuple<string, SortOrder>>(); } - var result = new ValueTuple<string, SortOrder>[sortBy.Count]; - for (var i = 0; i < sortBy.Count; i++) + var result = new (string, SortOrder)[sortBy.Count]; + var i = 0; + // Add elements which have a SortOrder specified + for (; i < requestedSortOrder.Count; i++) { - var sortOrderIndex = requestedSortOrder.Count > i ? i : 0; + result[i] = (sortBy[i], requestedSortOrder[i]); + } - var sortOrder = requestedSortOrder.Count > sortOrderIndex - ? requestedSortOrder[sortOrderIndex] - : SortOrder.Ascending; - result[i] = new ValueTuple<string, SortOrder>(sortBy[i], sortOrder); + // Add remaining elements with the default SortOrder + for (; i < sortBy.Count; i++) + { + result[i] = (sortBy[i], SortOrder.Ascending); } return result; |
