| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 | 
							- using System;
 
- using System.Linq;
 
- using MediaBrowser.Controller.Configuration;
 
- using MediaBrowser.Controller.Entities.Audio;
 
- using MediaBrowser.Controller.Library;
 
- using MediaBrowser.Controller.Resolvers;
 
- using MediaBrowser.Model.Entities;
 
- using MediaBrowser.Model.IO;
 
- using Microsoft.Extensions.Logging;
 
- namespace Emby.Server.Implementations.Library.Resolvers.Audio
 
- {
 
-     /// <summary>
 
-     /// Class MusicArtistResolver.
 
-     /// </summary>
 
-     public class MusicArtistResolver : ItemResolver<MusicArtist>
 
-     {
 
-         private readonly ILogger _logger;
 
-         private readonly IFileSystem _fileSystem;
 
-         private readonly ILibraryManager _libraryManager;
 
-         private readonly IServerConfigurationManager _config;
 
-         /// <summary>
 
-         /// Initializes a new instance of the <see cref="MusicArtistResolver"/> class.
 
-         /// </summary>
 
-         /// <param name="logger">The logger.</param>
 
-         /// <param name="fileSystem">The file system.</param>
 
-         /// <param name="libraryManager">The library manager.</param>
 
-         /// <param name="config">The configuration manager.</param>
 
-         public MusicArtistResolver(ILogger logger, IFileSystem fileSystem, ILibraryManager libraryManager, IServerConfigurationManager config)
 
-         {
 
-             _logger = logger;
 
-             _fileSystem = fileSystem;
 
-             _libraryManager = libraryManager;
 
-             _config = config;
 
-         }
 
-         /// <summary>
 
-         /// Gets the priority.
 
-         /// </summary>
 
-         /// <value>The priority.</value>
 
-         public override ResolverPriority Priority => ResolverPriority.Second;
 
-         /// <summary>
 
-         /// Resolves the specified args.
 
-         /// </summary>
 
-         /// <param name="args">The args.</param>
 
-         /// <returns>MusicArtist.</returns>
 
-         protected override MusicArtist Resolve(ItemResolveArgs args)
 
-         {
 
-             if (!args.IsDirectory)
 
-             {
 
-                 return null;
 
-             }
 
-             // Don't allow nested artists
 
-             if (args.HasParent<MusicArtist>() || args.HasParent<MusicAlbum>())
 
-             {
 
-                 return null;
 
-             }
 
-             var collectionType = args.GetCollectionType();
 
-             var isMusicMediaFolder = string.Equals(collectionType, CollectionType.Music, StringComparison.OrdinalIgnoreCase);
 
-             // If there's a collection type and it's not music, it can't be a series
 
-             if (!isMusicMediaFolder)
 
-             {
 
-                 return null;
 
-             }
 
-             if (args.ContainsFileSystemEntryByName("artist.nfo"))
 
-             {
 
-                 return new MusicArtist();
 
-             }
 
-             if (_config.Configuration.EnableSimpleArtistDetection)
 
-             {
 
-                 return null;
 
-             }
 
-             // Avoid mis-identifying top folders
 
-             if (args.Parent.IsRoot) return null;
 
-             var directoryService = args.DirectoryService;
 
-             var albumResolver = new MusicAlbumResolver(_logger, _fileSystem, _libraryManager);
 
-             // If we contain an album assume we are an artist folder
 
-             return args.FileSystemChildren.Where(i => i.IsDirectory).Any(i => albumResolver.IsMusicAlbum(i.FullName, directoryService, args.GetLibraryOptions())) ? new MusicArtist() : null;
 
-         }
 
-     }
 
- }
 
 
  |