using System;
using System.Text.RegularExpressions;
namespace Emby.Naming.Common
{
///
/// Regular expressions for parsing TV Episodes.
///
public class EpisodeExpression
{
private string _expression;
private Regex? _regex;
///
/// Initializes a new instance of the class.
///
/// Regular expressions.
/// True if date is expected.
public EpisodeExpression(string expression, bool byDate = false)
{
_expression = expression;
IsByDate = byDate;
DateTimeFormats = Array.Empty();
SupportsAbsoluteEpisodeNumbers = true;
}
///
/// Gets or sets raw expressions string.
///
public string Expression
{
get => _expression;
set
{
_expression = value;
_regex = null;
}
}
///
/// Gets or sets a value indicating whether gets or sets property indicating if date can be find in expression.
///
public bool IsByDate { get; set; }
///
/// Gets or sets a value indicating whether gets or sets property indicating if expression is optimistic.
///
public bool IsOptimistic { get; set; }
///
/// Gets or sets a value indicating whether gets or sets property indicating if expression is named.
///
public bool IsNamed { get; set; }
///
/// Gets or sets a value indicating whether gets or sets property indicating if expression supports episodes with absolute numbers.
///
public bool SupportsAbsoluteEpisodeNumbers { get; set; }
///
/// Gets or sets optional list of date formats used for date parsing.
///
public string[] DateTimeFormats { get; set; }
///
/// Gets a expressions objects (creates it if null).
///
public Regex Regex => _regex ??= new Regex(Expression, RegexOptions.IgnoreCase | RegexOptions.Compiled);
}
}