jellyfin/MediaBrowser.Server.Implementations/Library/Resolvers/TV/EpisodeResolver.cs

51 lines
1.4 KiB
C#
Raw Normal View History

2014-12-04 06:24:41 +01:00
using MediaBrowser.Controller.Entities.TV;
2013-02-21 02:33:05 +01:00
using MediaBrowser.Controller.Library;
2014-01-21 07:10:58 +01:00
using System.Linq;
2013-02-21 02:33:05 +01:00
namespace MediaBrowser.Server.Implementations.Library.Resolvers.TV
2013-02-21 02:33:05 +01:00
{
2013-02-23 08:57:11 +01:00
/// <summary>
/// Class EpisodeResolver
/// </summary>
public class EpisodeResolver : BaseVideoResolver<Episode>
2013-02-21 02:33:05 +01:00
{
2014-11-16 21:44:08 +01:00
public EpisodeResolver(ILibraryManager libraryManager) : base(libraryManager)
{
}
2013-02-23 08:57:11 +01:00
/// <summary>
/// Resolves the specified args.
/// </summary>
/// <param name="args">The args.</param>
/// <returns>Episode.</returns>
2013-02-21 02:33:05 +01:00
protected override Episode Resolve(ItemResolveArgs args)
{
2014-01-21 07:10:58 +01:00
var parent = args.Parent;
2014-01-22 18:05:06 +01:00
if (parent == null)
{
return null;
}
2014-01-21 07:10:58 +01:00
var season = parent as Season;
// Just in case the user decided to nest episodes.
// Not officially supported but in some cases we can handle it.
if (season == null)
{
2015-11-11 15:56:31 +01:00
season = parent.GetParents().OfType<Season>().FirstOrDefault();
2014-01-21 07:10:58 +01:00
}
2013-02-21 02:33:05 +01:00
// If the parent is a Season or Series, then this is an Episode if the VideoResolver returns something
2014-12-19 05:20:07 +01:00
if (season != null || args.HasParent<Series>())
2013-02-21 02:33:05 +01:00
{
2014-12-03 04:13:03 +01:00
var episode = ResolveVideo<Episode>(args, false);
return episode;
2013-02-21 02:33:05 +01:00
}
return null;
}
}
}