123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- using MediaBrowser.Model.Logging;
- using System;
- using System.Collections.Concurrent;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using CommonIO;
- namespace MediaBrowser.Controller.Providers
- {
- public class DirectoryService : IDirectoryService
- {
- private readonly ILogger _logger;
- private readonly IFileSystem _fileSystem;
- private readonly ConcurrentDictionary<string, Dictionary<string, FileSystemMetadata>> _cache =
- new ConcurrentDictionary<string, Dictionary<string, FileSystemMetadata>>(StringComparer.OrdinalIgnoreCase);
- public DirectoryService(ILogger logger, IFileSystem fileSystem)
- {
- _logger = logger;
- _fileSystem = fileSystem;
- }
- public DirectoryService(IFileSystem fileSystem)
- : this(new NullLogger(), fileSystem)
- {
- }
- public IEnumerable<FileSystemMetadata> GetFileSystemEntries(string path)
- {
- return GetFileSystemEntries(path, false);
- }
- public Dictionary<string, FileSystemMetadata> GetFileSystemDictionary(string path)
- {
- return GetFileSystemDictionary(path, false);
- }
- private Dictionary<string, FileSystemMetadata> GetFileSystemDictionary(string path, bool clearCache)
- {
- if (string.IsNullOrWhiteSpace(path))
- {
- throw new ArgumentNullException("path");
- }
- Dictionary<string, FileSystemMetadata> entries;
- if (clearCache)
- {
- Dictionary<string, FileSystemMetadata> removed;
- _cache.TryRemove(path, out removed);
- }
- if (!_cache.TryGetValue(path, out entries))
- {
- //_logger.Debug("Getting files for " + path);
- entries = new Dictionary<string, FileSystemMetadata>(StringComparer.OrdinalIgnoreCase);
-
- try
- {
- // using EnumerateFileSystemInfos doesn't handle reparse points (symlinks)
- var list = _fileSystem.GetFileSystemEntries(path)
- .ToList();
- // Seeing dupes on some users file system for some reason
- foreach (var item in list)
- {
- entries[item.FullName] = item;
- }
- }
- catch (DirectoryNotFoundException)
- {
- }
- //var group = entries.ToLookup(i => Path.GetDirectoryName(i.FullName)).ToList();
- _cache.TryAdd(path, entries);
- }
- return entries;
- }
- private IEnumerable<FileSystemMetadata> GetFileSystemEntries(string path, bool clearCache)
- {
- return GetFileSystemDictionary(path, clearCache).Values;
- }
- public IEnumerable<FileSystemMetadata> GetFiles(string path)
- {
- return GetFiles(path, false);
- }
- public IEnumerable<FileSystemMetadata> GetFiles(string path, bool clearCache)
- {
- return GetFileSystemEntries(path, clearCache).Where(i => !i.IsDirectory);
- }
- public FileSystemMetadata GetFile(string path)
- {
- return _fileSystem.GetFileInfo(path);
- //var directory = Path.GetDirectoryName(path);
- //if (string.IsNullOrWhiteSpace(directory))
- //{
- // _logger.Debug("Parent path is null for {0}", path);
- // return null;
- //}
- //try
- //{
- // var dict = GetFileSystemDictionary(directory, false);
- // FileSystemMetadata entry;
- // dict.TryGetValue(path, out entry);
- // return entry;
- //}
- //catch (Exception ex)
- //{
- // _logger.ErrorException("Error in GetFileSystemDictionary. Directory: :{0}. Original path: {1}", ex, directory, path);
- // return null;
- //}
- }
- public IEnumerable<FileSystemMetadata> GetDirectories(string path)
- {
- return GetFileSystemEntries(path, false).Where(i => i.IsDirectory);
- }
- }
- }
|