From c643dd072e117aec2397e695c650e8a58be2fc6c Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Fri, 27 Sep 2013 08:24:28 -0400 Subject: added more direct querying to folder --- .../Library/LibraryManager.cs | 14 ++++++++++---- .../Library/Validators/ArtistsValidator.cs | 2 +- .../Library/Validators/GenresValidator.cs | 2 +- .../Library/Validators/MusicGenresValidator.cs | 2 +- .../Library/Validators/PeoplePostScanTask.cs | 2 +- .../Library/Validators/StudiosValidator.cs | 2 +- 6 files changed, 15 insertions(+), 9 deletions(-) (limited to 'MediaBrowser.Server.Implementations/Library') diff --git a/MediaBrowser.Server.Implementations/Library/LibraryManager.cs b/MediaBrowser.Server.Implementations/Library/LibraryManager.cs index 084f9b05c..ebbefb239 100644 --- a/MediaBrowser.Server.Implementations/Library/LibraryManager.cs +++ b/MediaBrowser.Server.Implementations/Library/LibraryManager.cs @@ -337,7 +337,7 @@ namespace MediaBrowser.Server.Implementations.Library /// ConcurrentDictionary{GuidBaseItem}. private ConcurrentDictionary CreateLibraryItemsCache() { - var items = RootFolder.RecursiveChildren.ToList(); + var items = RootFolder.GetRecursiveChildren(); items.Add(RootFolder); @@ -347,7 +347,10 @@ namespace MediaBrowser.Server.Implementations.Library .Distinct() .ToList(); - items.AddRange(userRootFolders); + foreach (var folder in userRootFolders) + { + items.Add(folder); + } // Get all user collection folders // Skip BasePluginFolders because we already got them from RootFolder.RecursiveChildren @@ -355,7 +358,10 @@ namespace MediaBrowser.Server.Implementations.Library .Where(i => !(i is BasePluginFolder)) .ToList(); - items.AddRange(userFolders); + foreach (var folder in userFolders) + { + items.Add(folder); + } var dictionary = new ConcurrentDictionary(); @@ -770,7 +776,7 @@ namespace MediaBrowser.Server.Implementations.Library /// Task. public async Task ValidatePeople(CancellationToken cancellationToken, IProgress progress) { - var people = RootFolder.RecursiveChildren + var people = RootFolder.GetRecursiveChildren() .SelectMany(c => c.People) .DistinctBy(p => p.Name, StringComparer.OrdinalIgnoreCase) .ToList(); diff --git a/MediaBrowser.Server.Implementations/Library/Validators/ArtistsValidator.cs b/MediaBrowser.Server.Implementations/Library/Validators/ArtistsValidator.cs index 7c964eacb..903fe86be 100644 --- a/MediaBrowser.Server.Implementations/Library/Validators/ArtistsValidator.cs +++ b/MediaBrowser.Server.Implementations/Library/Validators/ArtistsValidator.cs @@ -57,7 +57,7 @@ namespace MediaBrowser.Server.Implementations.Library.Validators /// Task. public async Task Run(IProgress progress, CancellationToken cancellationToken) { - var allItems = _libraryManager.RootFolder.RecursiveChildren.ToList(); + var allItems = _libraryManager.RootFolder.GetRecursiveChildren(); var allMusicArtists = allItems.OfType().ToList(); var allSongs = allItems.OfType