jellyfin-server/Emby.Naming/TV/EpisodeResolver.cs

95 lines
3.6 KiB
C#
Raw Normal View History

using System;
2018-09-12 17:26:21 +00:00
using System.IO;
using System.Linq;
2019-01-13 19:17:29 +00:00
using Emby.Naming.Common;
using Emby.Naming.Video;
2018-09-12 17:26:21 +00:00
namespace Emby.Naming.TV
{
2020-11-10 18:23:10 +00:00
/// <summary>
/// Used to resolve information about episode from path.
/// </summary>
2018-09-12 17:26:21 +00:00
public class EpisodeResolver
{
private readonly NamingOptions _options;
2020-11-10 18:23:10 +00:00
/// <summary>
/// Initializes a new instance of the <see cref="EpisodeResolver"/> class.
/// </summary>
/// <param name="options"><see cref="NamingOptions"/> object containing VideoFileExtensions and passed to <see cref="StubResolver"/>, <see cref="FlagParser"/>, <see cref="Format3DParser"/> and <see cref="EpisodePathParser"/>.</param>
2018-09-12 17:26:21 +00:00
public EpisodeResolver(NamingOptions options)
{
_options = options;
}
2020-11-10 18:23:10 +00:00
/// <summary>
/// Resolve information about episode from path.
/// </summary>
/// <param name="path">Path.</param>
/// <param name="isDirectory">Is path for a directory or file.</param>
/// <param name="isNamed">Do we want to use IsNamed expressions.</param>
/// <param name="isOptimistic">Do we want to use Optimistic expressions.</param>
/// <param name="supportsAbsoluteNumbers">Do we want to use expressions supporting absolute episode numbers.</param>
/// <param name="fillExtendedInfo">Should we attempt to retrieve extended information.</param>
/// <returns>Returns null or <see cref="EpisodeInfo"/> object if successful.</returns>
2020-01-22 21:18:56 +00:00
public EpisodeInfo? Resolve(
2019-05-10 18:37:42 +00:00
string path,
bool isDirectory,
bool? isNamed = null,
bool? isOptimistic = null,
bool? supportsAbsoluteNumbers = null,
bool fillExtendedInfo = true)
2018-09-12 17:26:21 +00:00
{
bool isStub = false;
2020-01-22 21:18:56 +00:00
string? container = null;
string? stubType = null;
2018-09-12 17:26:21 +00:00
2019-05-10 18:37:42 +00:00
if (!isDirectory)
2018-09-12 17:26:21 +00:00
{
var extension = Path.GetExtension(path);
2018-09-12 17:26:21 +00:00
// Check supported extensions
if (!_options.VideoFileExtensions.Contains(extension, StringComparer.OrdinalIgnoreCase))
{
// It's not supported. Check stub extensions
2020-01-22 21:18:56 +00:00
if (!StubResolver.TryResolveFile(path, _options, out stubType))
2018-09-12 17:26:21 +00:00
{
return null;
}
2020-01-22 21:18:56 +00:00
isStub = true;
2018-09-12 17:26:21 +00:00
}
container = extension.TrimStart('.');
}
var flags = new FlagParser(_options).GetFlags(path);
var format3DResult = new Format3DParser(_options).Parse(flags);
var parsingResult = new EpisodePathParser(_options)
2019-05-10 18:37:42 +00:00
.Parse(path, isDirectory, isNamed, isOptimistic, supportsAbsoluteNumbers, fillExtendedInfo);
2019-01-07 23:27:46 +00:00
2021-04-09 13:05:39 +00:00
if (!parsingResult.Success && !isStub)
2021-04-09 11:43:40 +00:00
{
return null;
}
2020-11-01 09:47:31 +00:00
return new EpisodeInfo(path)
2018-09-12 17:26:21 +00:00
{
Container = container,
IsStub = isStub,
2020-11-01 10:19:22 +00:00
EndingEpisodeNumber = parsingResult.EndingEpisodeNumber,
2018-09-12 17:26:21 +00:00
EpisodeNumber = parsingResult.EpisodeNumber,
SeasonNumber = parsingResult.SeasonNumber,
SeriesName = parsingResult.SeriesName,
StubType = stubType,
Is3D = format3DResult.Is3D,
Format3D = format3DResult.Format3D,
IsByDate = parsingResult.IsByDate,
Day = parsingResult.Day,
Month = parsingResult.Month,
Year = parsingResult.Year
};
}
}
}