@ -200,9 +200,10 @@ namespace NzbDrone.Core.Parser
private static readonly string [ ] Numbers = new [ ] { "zero" , "one" , "two" , "three" , "four" , "five" , "six" , "seven" , "eight" , "nine" } ;
private static readonly string [ ] Numbers = new [ ] { "zero" , "one" , "two" , "three" , "four" , "five" , "six" , "seven" , "eight" , "nine" } ;
private static readonly Regex CommonTagRegex = new Regex ( @"(\[|\(){1}(version|deluxe|single|clean|album|special|bonus)+\s*.*(\]|\)){1}" , RegexOptions . IgnoreCase | RegexOptions . Compiled ) ;
public static ParsedTrackInfo ParseMusicPath ( string path )
public static ParsedTrackInfo ParseMusicPath ( string path )
{
{
var fileInfo = new FileInfo ( path ) ;
var fileInfo = new FileInfo ( path ) ;
var result = new ParsedTrackInfo { } ;
var result = new ParsedTrackInfo { } ;
@ -210,6 +211,12 @@ namespace NzbDrone.Core.Parser
if ( MediaFiles . MediaFileExtensions . Extensions . Contains ( fileInfo . Extension ) )
if ( MediaFiles . MediaFileExtensions . Extensions . Contains ( fileInfo . Extension ) )
{
{
result = ParseAudioTags ( path ) ;
result = ParseAudioTags ( path ) ;
if ( CommonTagRegex . IsMatch ( result . AlbumTitle ) )
{
result . AlbumTitle = CleanAlbumTitle ( result . AlbumTitle ) ;
Logger . Debug ( "Cleaning Album title of common matching issues. Cleaned album title is '{0}'" , result . AlbumTitle ) ;
}
}
}
else
else
{
{
@ -219,6 +226,8 @@ namespace NzbDrone.Core.Parser
// TODO: Check if it is common that we might need to fallback to parser to gather details
// TODO: Check if it is common that we might need to fallback to parser to gather details
//var result = ParseMusicTitle(fileInfo.Name);
//var result = ParseMusicTitle(fileInfo.Name);
if ( result = = null )
if ( result = = null )
{
{
Logger . Debug ( "Attempting to parse track info using directory and file names. {0}" , fileInfo . Directory . Name ) ;
Logger . Debug ( "Attempting to parse track info using directory and file names. {0}" , fileInfo . Directory . Name ) ;
@ -327,6 +336,7 @@ namespace NzbDrone.Core.Parser
Logger . Debug ( "Parsing string '{0}'" , title ) ;
Logger . Debug ( "Parsing string '{0}'" , title ) ;
if ( ReversedTitleRegex . IsMatch ( title ) )
if ( ReversedTitleRegex . IsMatch ( title ) )
{
{
var titleWithoutExtension = RemoveFileExtension ( title ) . ToCharArray ( ) ;
var titleWithoutExtension = RemoveFileExtension ( title ) . ToCharArray ( ) ;
@ -407,6 +417,7 @@ namespace NzbDrone.Core.Parser
Logger . Debug ( "Parsing string '{0}'" , title ) ;
Logger . Debug ( "Parsing string '{0}'" , title ) ;
if ( ReversedTitleRegex . IsMatch ( title ) )
if ( ReversedTitleRegex . IsMatch ( title ) )
{
{
var titleWithoutExtension = RemoveFileExtension ( title ) . ToCharArray ( ) ;
var titleWithoutExtension = RemoveFileExtension ( title ) . ToCharArray ( ) ;
@ -582,6 +593,16 @@ namespace NzbDrone.Core.Parser
return title ;
return title ;
}
}
public static string CleanAlbumTitle ( string album )
{
return CommonTagRegex . Replace ( album , string . Empty ) . Trim ( ) ;
}
public static string CleanTrackTitle ( string title )
{
return CommonTagRegex . Replace ( title , string . Empty ) . Trim ( ) ;
}
private static ParsedTrackInfo ParseAudioTags ( string path )
private static ParsedTrackInfo ParseAudioTags ( string path )
{
{
var file = TagLib . File . Create ( path ) ;
var file = TagLib . File . Create ( path ) ;