|
|
|
@ -25,26 +25,54 @@ namespace Emby.Naming.Video
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var len = expressions.Count;
|
|
|
|
|
for (int i = 0; i < len; i++)
|
|
|
|
|
// Iteratively remove extra cruft until we're left with the string
|
|
|
|
|
// we want.
|
|
|
|
|
newName = ReadOnlySpan<char>.Empty;
|
|
|
|
|
const int maxTries = 100; // This is just a precautionary
|
|
|
|
|
// measure. Should not be neccesary.
|
|
|
|
|
var loopCounter = 0;
|
|
|
|
|
for (; loopCounter < maxTries; loopCounter++)
|
|
|
|
|
{
|
|
|
|
|
if (TryClean(name, expressions[i], out newName))
|
|
|
|
|
bool cleaned = false;
|
|
|
|
|
var len = expressions.Count;
|
|
|
|
|
for (int i = 0; i < len; i++)
|
|
|
|
|
{
|
|
|
|
|
if (TryClean(name, expressions[i], out newName))
|
|
|
|
|
{
|
|
|
|
|
cleaned = true;
|
|
|
|
|
name = newName.ToString();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!cleaned)
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
newName = ReadOnlySpan<char>.Empty;
|
|
|
|
|
return false;
|
|
|
|
|
if (loopCounter > 0)
|
|
|
|
|
{
|
|
|
|
|
newName = name.AsSpan();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return newName != ReadOnlySpan<char>.Empty;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static bool TryClean(string name, Regex expression, out ReadOnlySpan<char> newName)
|
|
|
|
|
{
|
|
|
|
|
var match = expression.Match(name);
|
|
|
|
|
int index = match.Index;
|
|
|
|
|
if (match.Success && index != 0)
|
|
|
|
|
if (match.Success)
|
|
|
|
|
{
|
|
|
|
|
newName = name.AsSpan().Slice(0, match.Index);
|
|
|
|
|
var found = match.Groups.TryGetValue("cleaned", out var cleaned);
|
|
|
|
|
if (!found || cleaned == null)
|
|
|
|
|
{
|
|
|
|
|
newName = ReadOnlySpan<char>.Empty;
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
newName = name.AsSpan().Slice(cleaned.Index, cleaned.Length);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|