5a8e972952
Analyzers are only run in debug build, so setting TreatWarningsAsErrors for release build will catch the compiler warnings until we resolve all analyzer warnings.
69 lines
1.9 KiB
C#
69 lines
1.9 KiB
C#
#pragma warning disable CS1591
|
|
#pragma warning disable SA1600
|
|
|
|
using System;
|
|
using System.Globalization;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Text.RegularExpressions;
|
|
using Emby.Naming.Common;
|
|
|
|
namespace Emby.Naming.Audio
|
|
{
|
|
public class AlbumParser
|
|
{
|
|
private readonly NamingOptions _options;
|
|
|
|
public AlbumParser(NamingOptions options)
|
|
{
|
|
_options = options;
|
|
}
|
|
|
|
public MultiPartResult ParseMultiPart(string path)
|
|
{
|
|
var result = new MultiPartResult();
|
|
|
|
var filename = Path.GetFileName(path);
|
|
|
|
if (string.IsNullOrEmpty(filename))
|
|
{
|
|
return result;
|
|
}
|
|
|
|
// TODO: Move this logic into options object
|
|
// Even better, remove the prefixes and come up with regexes
|
|
// But Kodi documentation seems to be weak for audio
|
|
|
|
// Normalize
|
|
// Remove whitespace
|
|
filename = filename.Replace('-', ' ');
|
|
filename = filename.Replace('.', ' ');
|
|
filename = filename.Replace('(', ' ');
|
|
filename = filename.Replace(')', ' ');
|
|
filename = Regex.Replace(filename, @"\s+", " ");
|
|
|
|
filename = filename.TrimStart();
|
|
|
|
foreach (var prefix in _options.AlbumStackingPrefixes)
|
|
{
|
|
if (filename.IndexOf(prefix, StringComparison.OrdinalIgnoreCase) != 0)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
var tmp = filename.Substring(prefix.Length);
|
|
|
|
tmp = tmp.Trim().Split(' ').FirstOrDefault() ?? string.Empty;
|
|
|
|
if (int.TryParse(tmp, NumberStyles.Integer, CultureInfo.InvariantCulture, out _))
|
|
{
|
|
result.IsMultiPart = true;
|
|
break;
|
|
}
|
|
}
|
|
|
|
return result;
|
|
}
|
|
}
|
|
}
|