diff --git a/MediaBrowser.Controller/Entities/BaseItem.cs b/MediaBrowser.Controller/Entities/BaseItem.cs index 264f66945..4c5575ae3 100644 --- a/MediaBrowser.Controller/Entities/BaseItem.cs +++ b/MediaBrowser.Controller/Entities/BaseItem.cs @@ -269,17 +269,29 @@ namespace MediaBrowser.Controller.Entities private Guid GetFileSystemStamp() { // If there's no path or the item is a file, there's nothing to do - if (LocationType != LocationType.FileSystem || !ResolveArgs.IsDirectory) + if (LocationType != LocationType.FileSystem) { return Guid.Empty; } + + try + { + if (!ResolveArgs.IsDirectory) + { + return Guid.Empty; + } + } + catch (IOException ex) + { + Logger.ErrorException("Error determining if path is directory: {0}", ex, ResolveArgs.Path); + throw; + } var sb = new StringBuilder(); // 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 => (i.Attributes & FileAttributes.System) != FileAttributes.System) .OrderBy(f => f.Name)) { sb.Append(file.Name); @@ -491,48 +503,6 @@ namespace MediaBrowser.Controller.Entities [IgnoreDataMember] public Folder Parent { get; set; } - /// - /// Gets the collection folder parent. - /// - /// The collection folder parent. - [IgnoreDataMember] - public Folder CollectionFolder - { - get - { - if (this is AggregateFolder) - { - return null; - } - - if (IsFolder) - { - var iCollectionFolder = this as ICollectionFolder; - - if (iCollectionFolder != null) - { - return (Folder)this; - } - } - - var parent = Parent; - - while (parent != null) - { - var iCollectionFolder = parent as ICollectionFolder; - - if (iCollectionFolder != null) - { - return parent; - } - - parent = parent.Parent; - } - - return null; - } - } - /// /// When the item first debuted. For movies this could be premiere date, episodes would be first aired ///