diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2015-04-09 17:11:57 -0400 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2015-04-09 17:11:57 -0400 |
| commit | 1b600aee37fbcbe27ba48e669b5ada790aa4c5da (patch) | |
| tree | 48f61282a83f3715608f1d4363284deb892531b4 /MediaBrowser.Controller/Library/NameExtensions.cs | |
| parent | 1b549adf0fae6d54a2bd1187ce4013ef802b85f2 (diff) | |
improve name matching
Diffstat (limited to 'MediaBrowser.Controller/Library/NameExtensions.cs')
| -rw-r--r-- | MediaBrowser.Controller/Library/NameExtensions.cs | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/MediaBrowser.Controller/Library/NameExtensions.cs b/MediaBrowser.Controller/Library/NameExtensions.cs new file mode 100644 index 000000000..b2acdc7ea --- /dev/null +++ b/MediaBrowser.Controller/Library/NameExtensions.cs @@ -0,0 +1,41 @@ +using MediaBrowser.Common.Extensions; +using MoreLinq; +using System; +using System.Collections.Generic; +using System.Linq; + +namespace MediaBrowser.Controller.Library +{ + public static class NameExtensions + { + public static bool AreEqual(string name1, string name2) + { + name1 = NormalizeForComparison(name1); + name2 = NormalizeForComparison(name2); + + return string.Equals(name1, name2, StringComparison.OrdinalIgnoreCase); + } + + public static bool EqualsAny(IEnumerable<string> names, string name) + { + name = NormalizeForComparison(name); + + return names.Any(i => string.Equals(NormalizeForComparison(i), name, StringComparison.OrdinalIgnoreCase)); + } + + private static string NormalizeForComparison(string name) + { + if (string.IsNullOrWhiteSpace(name)) + { + return string.Empty; + } + + return name.RemoveDiacritics(); + } + + public static IEnumerable<string> DistinctNames(this IEnumerable<string> names) + { + return names.DistinctBy(NormalizeForComparison, StringComparer.OrdinalIgnoreCase); + } + } +} |
