From 34bf41721ac33ef42b33bde7d30f12f107ea7aeb Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Thu, 15 Aug 2013 12:21:32 -0400 Subject: [PATCH] Additional fixes for multiple movies per folder. Added a provider shell --- .../Entities/TV/Episode.cs | 9 ++ .../Resolvers/BaseVideoResolver.cs | 3 +- .../ImageFromMixedMediaLocationProvider.cs | 95 +++++++++++++++++++ .../MediaBrowser.Providers.csproj | 1 + .../Providers/ImageSaver.cs | 13 ++- 5 files changed, 115 insertions(+), 6 deletions(-) create mode 100644 MediaBrowser.Providers/ImageFromMixedMediaLocationProvider.cs diff --git a/MediaBrowser.Controller/Entities/TV/Episode.cs b/MediaBrowser.Controller/Entities/TV/Episode.cs index 737fa9fd63..9a2acc1081 100644 --- a/MediaBrowser.Controller/Entities/TV/Episode.cs +++ b/MediaBrowser.Controller/Entities/TV/Episode.cs @@ -22,6 +22,15 @@ namespace MediaBrowser.Controller.Entities.TV } } + [IgnoreDataMember] + protected override bool UseParentPathToCreateResolveArgs + { + get + { + return true; + } + } + /// /// We want to group into series not show individually in an index /// diff --git a/MediaBrowser.Controller/Resolvers/BaseVideoResolver.cs b/MediaBrowser.Controller/Resolvers/BaseVideoResolver.cs index 0ed02c10f0..aadaf54231 100644 --- a/MediaBrowser.Controller/Resolvers/BaseVideoResolver.cs +++ b/MediaBrowser.Controller/Resolvers/BaseVideoResolver.cs @@ -45,7 +45,8 @@ namespace MediaBrowser.Controller.Resolvers return new TVideoType { VideoType = type, - Path = args.Path + Path = args.Path, + IsInMixedFolder = true }; } } diff --git a/MediaBrowser.Providers/ImageFromMixedMediaLocationProvider.cs b/MediaBrowser.Providers/ImageFromMixedMediaLocationProvider.cs new file mode 100644 index 0000000000..1539c9ddca --- /dev/null +++ b/MediaBrowser.Providers/ImageFromMixedMediaLocationProvider.cs @@ -0,0 +1,95 @@ +using MediaBrowser.Controller.Configuration; +using MediaBrowser.Controller.Entities; +using MediaBrowser.Controller.Entities.TV; +using MediaBrowser.Controller.Library; +using MediaBrowser.Controller.Providers; +using MediaBrowser.Model.Entities; +using MediaBrowser.Model.Logging; +using System.Threading; +using System.Threading.Tasks; + +namespace MediaBrowser.Providers +{ + class ImageFromMixedMediaLocationProvider : BaseMetadataProvider + { + public ImageFromMixedMediaLocationProvider(ILogManager logManager, IServerConfigurationManager configurationManager) + : base(logManager, configurationManager) + { + } + + public override ItemUpdateType ItemUpdateType + { + get + { + return ItemUpdateType.ImageUpdate; + } + } + + /// + /// Supportses the specified item. + /// + /// The item. + /// true if XXXX, false otherwise + public override bool Supports(BaseItem item) + { + if (item.LocationType != LocationType.FileSystem || item.ResolveArgs.IsDirectory) + { + return false; + } + + var video = item as Video; + + if (video != null && !(item is Episode)) + { + return video.IsInMixedFolder; + } + + var game = item as Game; + + if (game != null) + { + return game.IsInMixedFolder; + } + + return false; + } + + /// + /// Gets the priority. + /// + /// The priority. + public override MetadataProviderPriority Priority + { + get { return MetadataProviderPriority.First; } + } + + /// + /// Returns true or false indicating if the provider should refresh when the contents of it's directory changes + /// + /// true if [refresh on file system stamp change]; otherwise, false. + protected override bool RefreshOnFileSystemStampChange + { + get + { + return true; + } + } + + /// + /// Gets the filestamp extensions. + /// + /// The filestamp extensions. + protected override string[] FilestampExtensions + { + get + { + return BaseItem.SupportedImageExtensions; + } + } + + public override Task FetchAsync(BaseItem item, bool force, CancellationToken cancellationToken) + { + return TrueTaskResult; + } + } +} diff --git a/MediaBrowser.Providers/MediaBrowser.Providers.csproj b/MediaBrowser.Providers/MediaBrowser.Providers.csproj index 28e6173789..1b429890a0 100644 --- a/MediaBrowser.Providers/MediaBrowser.Providers.csproj +++ b/MediaBrowser.Providers/MediaBrowser.Providers.csproj @@ -52,6 +52,7 @@ + diff --git a/MediaBrowser.Server.Implementations/Providers/ImageSaver.cs b/MediaBrowser.Server.Implementations/Providers/ImageSaver.cs index 615f9d8a00..4a3e7e7a60 100644 --- a/MediaBrowser.Server.Implementations/Providers/ImageSaver.cs +++ b/MediaBrowser.Server.Implementations/Providers/ImageSaver.cs @@ -242,13 +242,16 @@ namespace MediaBrowser.Server.Implementations.Providers if (saveLocally) { - var video = item as Video; - - if (video != null && video.IsInMixedFolder) + if (!(item is Episode)) { - var folder = Path.GetDirectoryName(video.Path); + var video = item as Video; - path = Path.Combine(folder, Path.GetFileNameWithoutExtension(video.Path) + "-" + filename); + if (video != null && video.IsInMixedFolder) + { + var folder = Path.GetDirectoryName(video.Path); + + path = Path.Combine(folder, Path.GetFileNameWithoutExtension(video.Path) + "-" + filename); + } } if (string.IsNullOrEmpty(path) && !string.IsNullOrEmpty(item.MetaLocation))