From 11d91faaada0e70910c832ce405ddeed52a24172 Mon Sep 17 00:00:00 2001 From: Stepan Goremykin Date: Sun, 26 Mar 2023 20:40:51 -0700 Subject: [PATCH] Use Array.Empty and fix a few multiple enumerations --- src/NzbDrone.Common/Composition/AssemblyLoader.cs | 7 ++++--- .../OAuth/WebParameterCollection.cs | 4 ++-- .../DailySeries/DailySeriesDataProxy.cs | 2 +- src/NzbDrone.Core/Datastore/BasicRepository.cs | 2 +- .../Proxies/DownloadStationTaskProxyV1.cs | 3 ++- .../Proxies/DownloadStationTaskProxyV2.cs | 3 ++- .../Extras/Metadata/MetadataService.cs | 2 +- .../ImportLists/Simkl/SimklImportBase.cs | 2 +- src/NzbDrone.Core/Indexers/HttpIndexerBase.cs | 14 +++++++------- src/NzbDrone.Core/Indexers/RssParser.cs | 2 +- .../EpisodeImport/ImportApprovedEpisodes.cs | 13 +++++++------ src/NzbDrone.Core/Tv/RefreshEpisodeService.cs | 2 +- src/Sonarr.Api.V3/ProviderControllerBase.cs | 6 +++--- src/Sonarr.Http/REST/RestController.cs | 4 +++- 14 files changed, 36 insertions(+), 30 deletions(-) diff --git a/src/NzbDrone.Common/Composition/AssemblyLoader.cs b/src/NzbDrone.Common/Composition/AssemblyLoader.cs index 67faadea1..cf5d68151 100644 --- a/src/NzbDrone.Common/Composition/AssemblyLoader.cs +++ b/src/NzbDrone.Common/Composition/AssemblyLoader.cs @@ -16,7 +16,7 @@ static AssemblyLoader() AppDomain.CurrentDomain.AssemblyResolve += new ResolveEventHandler(ContainerResolveEventHandler); } - public static IEnumerable Load(IEnumerable assemblyNames) + public static IList Load(IList assemblyNames) { var toLoad = assemblyNames.ToList(); toLoad.Add("Sonarr.Common"); @@ -28,8 +28,9 @@ public static IEnumerable Load(IEnumerable assemblyNames) var startupPath = AppDomain.CurrentDomain.BaseDirectory; - return toLoad.Select(x => - AssemblyLoadContext.Default.LoadFromAssemblyPath(Path.Combine(startupPath, $"{x}.dll"))); + return toLoad + .Select(x => AssemblyLoadContext.Default.LoadFromAssemblyPath(Path.Combine(startupPath, $"{x}.dll"))) + .ToList(); } private static Assembly ContainerResolveEventHandler(object sender, ResolveEventArgs args) diff --git a/src/NzbDrone.Common/OAuth/WebParameterCollection.cs b/src/NzbDrone.Common/OAuth/WebParameterCollection.cs index 5f905872e..f1244554c 100644 --- a/src/NzbDrone.Common/OAuth/WebParameterCollection.cs +++ b/src/NzbDrone.Common/OAuth/WebParameterCollection.cs @@ -15,14 +15,14 @@ public virtual WebParameter this[string name] { get { - var parameters = this.Where(p => p.Name.Equals(name)); + var parameters = this.Where(p => p.Name.Equals(name)).ToArray(); if (parameters.Empty()) { return null; } - if (parameters.Count() == 1) + if (parameters.Length == 1) { return parameters.Single(); } diff --git a/src/NzbDrone.Core/DataAugmentation/DailySeries/DailySeriesDataProxy.cs b/src/NzbDrone.Core/DataAugmentation/DailySeries/DailySeriesDataProxy.cs index 41eae4f29..f1110bb37 100644 --- a/src/NzbDrone.Core/DataAugmentation/DailySeries/DailySeriesDataProxy.cs +++ b/src/NzbDrone.Core/DataAugmentation/DailySeries/DailySeriesDataProxy.cs @@ -39,7 +39,7 @@ public IEnumerable GetDailySeriesIds() catch (Exception ex) { _logger.Warn(ex, "Failed to get Daily Series"); - return new List(); + return Array.Empty(); } } } diff --git a/src/NzbDrone.Core/Datastore/BasicRepository.cs b/src/NzbDrone.Core/Datastore/BasicRepository.cs index c7d6a2230..5f59e9e8a 100644 --- a/src/NzbDrone.Core/Datastore/BasicRepository.cs +++ b/src/NzbDrone.Core/Datastore/BasicRepository.cs @@ -111,7 +111,7 @@ public IEnumerable Get(IEnumerable ids) { if (!ids.Any()) { - return new List(); + return Array.Empty(); } var result = Query(x => ids.Contains(x.Id)); diff --git a/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV1.cs b/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV1.cs index 466a8c49c..13e5131fb 100644 --- a/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV1.cs +++ b/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV1.cs @@ -1,3 +1,4 @@ +using System; using System.Collections.Generic; using System.Net.Http; using NLog; @@ -61,7 +62,7 @@ public IEnumerable GetTasks(DownloadStationSettings setting catch (DownloadClientException e) { _logger.Error(e); - return new List(); + return Array.Empty(); } } diff --git a/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV2.cs b/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV2.cs index 0812b76d4..6f81c3ac3 100644 --- a/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV2.cs +++ b/src/NzbDrone.Core/Download/Clients/DownloadStation/Proxies/DownloadStationTaskProxyV2.cs @@ -1,3 +1,4 @@ +using System; using System.Collections.Generic; using System.Linq; using System.Net.Http; @@ -102,7 +103,7 @@ public IEnumerable GetTasks(DownloadStationSettings setting catch (DownloadClientException e) { _logger.Error(e); - return new List(); + return Array.Empty(); } } diff --git a/src/NzbDrone.Core/Extras/Metadata/MetadataService.cs b/src/NzbDrone.Core/Extras/Metadata/MetadataService.cs index 545856417..d88c0398d 100644 --- a/src/NzbDrone.Core/Extras/Metadata/MetadataService.cs +++ b/src/NzbDrone.Core/Extras/Metadata/MetadataService.cs @@ -136,7 +136,7 @@ public override IEnumerable CreateAfterEpisodeFolder(Series series, s if (seriesFolder.IsNullOrWhiteSpace() && seasonFolder.IsNullOrWhiteSpace()) { - return new List(); + return Array.Empty(); } var files = new List(); diff --git a/src/NzbDrone.Core/ImportLists/Simkl/SimklImportBase.cs b/src/NzbDrone.Core/ImportLists/Simkl/SimklImportBase.cs index f6daf9e5f..6b7ba596e 100644 --- a/src/NzbDrone.Core/ImportLists/Simkl/SimklImportBase.cs +++ b/src/NzbDrone.Core/ImportLists/Simkl/SimklImportBase.cs @@ -51,7 +51,7 @@ public override IList Fetch() // Check to see if user has any activity since last sync, if not return empty to avoid work if (lastFetch.HasValue && lastActivity < lastFetch.Value.AddHours(-2)) { - return new List(); + return Array.Empty(); } var generator = GetRequestGenerator(); diff --git a/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs b/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs index 5c0594013..6abaf1995 100644 --- a/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs +++ b/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs @@ -43,7 +43,7 @@ public override IList FetchRecent() { if (!SupportsRss) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetRecentRequests(), true); @@ -53,7 +53,7 @@ public override IList Fetch(SingleEpisodeSearchCriteria searchCrite { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); @@ -63,7 +63,7 @@ public override IList Fetch(SeasonSearchCriteria searchCriteria) { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); @@ -73,7 +73,7 @@ public override IList Fetch(DailyEpisodeSearchCriteria searchCriter { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); @@ -83,7 +83,7 @@ public override IList Fetch(DailySeasonSearchCriteria searchCriteri { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); @@ -93,7 +93,7 @@ public override IList Fetch(AnimeEpisodeSearchCriteria searchCriter { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); @@ -103,7 +103,7 @@ public override IList Fetch(SpecialEpisodeSearchCriteria searchCrit { if (!SupportsSearch) { - return new List(); + return Array.Empty(); } return FetchReleases(g => g.GetSearchRequests(searchCriteria)); diff --git a/src/NzbDrone.Core/Indexers/RssParser.cs b/src/NzbDrone.Core/Indexers/RssParser.cs index d6260b012..dfe83e291 100644 --- a/src/NzbDrone.Core/Indexers/RssParser.cs +++ b/src/NzbDrone.Core/Indexers/RssParser.cs @@ -84,7 +84,7 @@ public virtual IList ParseResponse(IndexerResponse indexerResponse) if (!PostProcess(indexerResponse, items, releases)) { - return new List(); + return Array.Empty(); } return releases; diff --git a/src/NzbDrone.Core/MediaFiles/EpisodeImport/ImportApprovedEpisodes.cs b/src/NzbDrone.Core/MediaFiles/EpisodeImport/ImportApprovedEpisodes.cs index 6e198c7bd..096ccd0cf 100644 --- a/src/NzbDrone.Core/MediaFiles/EpisodeImport/ImportApprovedEpisodes.cs +++ b/src/NzbDrone.Core/MediaFiles/EpisodeImport/ImportApprovedEpisodes.cs @@ -51,12 +51,13 @@ public ImportApprovedEpisodes(IUpgradeMediaFiles episodeFileUpgrader, public List Import(List decisions, bool newDownload, DownloadClientItem downloadClientItem = null, ImportMode importMode = ImportMode.Auto) { - var qualifiedImports = decisions.Where(c => c.Approved) - .GroupBy(c => c.LocalEpisode.Series.Id, (i, s) => s - .OrderByDescending(c => c.LocalEpisode.Quality, new QualityModelComparer(s.First().LocalEpisode.Series.QualityProfile)) - .ThenByDescending(c => c.LocalEpisode.Size)) - .SelectMany(c => c) - .ToList(); + var qualifiedImports = decisions + .Where(decision => decision.Approved) + .GroupBy(decision => decision.LocalEpisode.Series.Id) + .SelectMany(group => group + .OrderByDescending(decision => decision.LocalEpisode.Quality, new QualityModelComparer(group.First().LocalEpisode.Series.QualityProfile)) + .ThenByDescending(decision => decision.LocalEpisode.Size)) + .ToList(); var importResults = new List(); diff --git a/src/NzbDrone.Core/Tv/RefreshEpisodeService.cs b/src/NzbDrone.Core/Tv/RefreshEpisodeService.cs index 7e41b0b91..caa245c5d 100644 --- a/src/NzbDrone.Core/Tv/RefreshEpisodeService.cs +++ b/src/NzbDrone.Core/Tv/RefreshEpisodeService.cs @@ -186,7 +186,7 @@ private void AdjustMultiEpisodeAirTime(Series series, IEnumerable allEp } } - private void AdjustDirectToDvdAirDate(Series series, IEnumerable allEpisodes) + private void AdjustDirectToDvdAirDate(Series series, IList allEpisodes) { if (series.Status == SeriesStatusType.Ended && allEpisodes.All(v => !v.AirDateUtc.HasValue) && series.FirstAired.HasValue) { diff --git a/src/Sonarr.Api.V3/ProviderControllerBase.cs b/src/Sonarr.Api.V3/ProviderControllerBase.cs index 48ac2a8fd..cee4327d3 100644 --- a/src/Sonarr.Api.V3/ProviderControllerBase.cs +++ b/src/Sonarr.Api.V3/ProviderControllerBase.cs @@ -45,11 +45,11 @@ protected override TProviderResource GetResourceById(int id) [Produces("application/json")] public List GetAll() { - var providerDefinitions = _providerFactory.All().OrderBy(p => p.ImplementationName); + var providerDefinitions = _providerFactory.All(); - var result = new List(providerDefinitions.Count()); + var result = new List(providerDefinitions.Count); - foreach (var definition in providerDefinitions) + foreach (var definition in providerDefinitions.OrderBy(p => p.ImplementationName)) { _providerFactory.SetProviderCharacteristics(definition); diff --git a/src/Sonarr.Http/REST/RestController.cs b/src/Sonarr.Http/REST/RestController.cs index 180b2a25a..db574bb50 100644 --- a/src/Sonarr.Http/REST/RestController.cs +++ b/src/Sonarr.Http/REST/RestController.cs @@ -1,6 +1,7 @@ using System; using System.Collections.Generic; using System.Linq; +using System.Reflection; using FluentValidation; using FluentValidation.Results; using Microsoft.AspNetCore.Mvc; @@ -87,7 +88,8 @@ public override void OnActionExecuting(ActionExecutingContext context) } } - var attributes = descriptor.MethodInfo.CustomAttributes; + var attributes = descriptor.MethodInfo.CustomAttributes as IReadOnlyCollection ?? + descriptor.MethodInfo.CustomAttributes.ToArray(); if (attributes.Any(x => VALIDATE_ID_ATTRIBUTES.Contains(x.AttributeType)) && !skipValidate) { if (context.ActionArguments.TryGetValue("id", out var idObj))