aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Controller
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2013-10-13 21:35:47 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2013-10-13 21:35:47 -0400
commitb5059152fefe68ae47252dba3b7785cc9770629e (patch)
treeee027da06745cea3730b68f3992f0ca8e5793cbf /MediaBrowser.Controller
parentbef67412b15cc0210d9d2c4c7b174691d3049fd7 (diff)
fixes #586 - Support extrafanart folder for backdrops
Diffstat (limited to 'MediaBrowser.Controller')
-rw-r--r--MediaBrowser.Controller/Providers/BaseMetadataProvider.cs62
1 files changed, 33 insertions, 29 deletions
diff --git a/MediaBrowser.Controller/Providers/BaseMetadataProvider.cs b/MediaBrowser.Controller/Providers/BaseMetadataProvider.cs
index 2d49708fe..10c5c116a 100644
--- a/MediaBrowser.Controller/Providers/BaseMetadataProvider.cs
+++ b/MediaBrowser.Controller/Providers/BaseMetadataProvider.cs
@@ -354,7 +354,7 @@ namespace MediaBrowser.Controller.Providers
}
private Dictionary<string, string> _fileStampExtensionsDictionary;
- private Dictionary<string, string> FileStampExtensionsDictionary
+ private Dictionary<string, string> FileStampExtensionsDictionary
{
get
{
@@ -400,46 +400,50 @@ namespace MediaBrowser.Controller.Providers
// Record the name of each file
// Need to sort these because accoring to msdn docs, our i/o methods are not guaranteed in any order
- foreach (var file in resolveArgs.FileSystemChildren
- .Where(i => IncludeInFileStamp(i, extensions, numExtensions))
- .OrderBy(f => f.Name))
- {
- sb.Append(file.Name);
- }
-
- foreach (var file in resolveArgs.MetadataFiles
- .Where(i => IncludeInFileStamp(i, extensions, numExtensions))
- .OrderBy(f => f.Name))
- {
- sb.Append(file.Name);
- }
+ AddFiles(sb, resolveArgs.FileSystemChildren, extensions, numExtensions);
+ AddFiles(sb, resolveArgs.MetadataFiles, extensions, numExtensions);
return sb.ToString().GetMD5();
}
+ private static readonly Dictionary<string, string> FoldersToMonitor = new[] { "extrafanart" }
+ .ToDictionary(i => i, StringComparer.OrdinalIgnoreCase);
+
/// <summary>
- /// Includes the in file stamp.
+ /// Adds the files.
/// </summary>
- /// <param name="file">The file.</param>
+ /// <param name="sb">The sb.</param>
+ /// <param name="files">The files.</param>
/// <param name="extensions">The extensions.</param>
/// <param name="numExtensions">The num extensions.</param>
- /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
- private bool IncludeInFileStamp(FileSystemInfo file, Dictionary<string,string> extensions, int numExtensions)
+ private void AddFiles(StringBuilder sb, IEnumerable<FileSystemInfo> files, Dictionary<string, string> extensions, int numExtensions)
{
- try
+ foreach (var file in files
+ .OrderBy(f => f.Name))
{
- if ((file.Attributes & FileAttributes.Directory) == FileAttributes.Directory)
+ try
{
- return false;
+ if ((file.Attributes & FileAttributes.Directory) == FileAttributes.Directory)
+ {
+ if (FoldersToMonitor.ContainsKey(file.Name))
+ {
+ sb.Append(file.Name);
+
+ var children = ((DirectoryInfo) file).EnumerateFiles("*", SearchOption.TopDirectoryOnly).ToList();
+ AddFiles(sb, children, extensions, numExtensions);
+ }
+ }
+
+ // It's a file
+ else if (numExtensions == 0 || extensions.ContainsKey(file.Extension))
+ {
+ sb.Append(file.Name);
+ }
+ }
+ catch (IOException ex)
+ {
+ Logger.ErrorException("Error accessing file attributes for {0}", ex, file.FullName);
}
-
- return numExtensions == 0 || extensions.ContainsKey(file.Extension);
- }
- catch (IOException ex)
- {
- Logger.ErrorException("Error accessing file attributes for {0}", ex, file.FullName);
-
- return false;
}
}
}