aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common/Extensions/EnumerableExtensions.cs
diff options
context:
space:
mode:
authorBond-009 <bond.009@outlook.com>2021-05-20 22:46:40 +0200
committerGitHub <noreply@github.com>2021-05-20 22:46:40 +0200
commita7b7ff000bdff1f089dc9d68347058fe8314f509 (patch)
treec1d9f36e3fc4bb6679f9793374370e3de553fc25 /MediaBrowser.Common/Extensions/EnumerableExtensions.cs
parentee7a95e088520f835a4d179c7c5faec5eaa8f9ff (diff)
parente8790bfa963284863dc1126a83df72309ec30561 (diff)
Merge branch 'master' into tmdb-person-language
Diffstat (limited to 'MediaBrowser.Common/Extensions/EnumerableExtensions.cs')
-rw-r--r--MediaBrowser.Common/Extensions/EnumerableExtensions.cs51
1 files changed, 51 insertions, 0 deletions
diff --git a/MediaBrowser.Common/Extensions/EnumerableExtensions.cs b/MediaBrowser.Common/Extensions/EnumerableExtensions.cs
new file mode 100644
index 000000000..2b8a6c395
--- /dev/null
+++ b/MediaBrowser.Common/Extensions/EnumerableExtensions.cs
@@ -0,0 +1,51 @@
+using System;
+using System.Collections.Generic;
+
+namespace MediaBrowser.Common.Extensions
+{
+ /// <summary>
+ /// Static extensions for the <see cref="IEnumerable{T}"/> interface.
+ /// </summary>
+ public static class EnumerableExtensions
+ {
+ /// <summary>
+ /// Determines whether the value is contained in the source collection.
+ /// </summary>
+ /// <param name="source">An instance of the <see cref="IEnumerable{String}"/> interface.</param>
+ /// <param name="value">The value to look for in the collection.</param>
+ /// <param name="stringComparison">The string comparison.</param>
+ /// <returns>A value indicating whether the value is contained in the collection.</returns>
+ /// <exception cref="ArgumentNullException">The source is null.</exception>
+ public static bool Contains(this IEnumerable<string> source, ReadOnlySpan<char> value, StringComparison stringComparison)
+ {
+ if (source == null)
+ {
+ throw new ArgumentNullException(nameof(source));
+ }
+
+ if (source is IList<string> list)
+ {
+ int len = list.Count;
+ for (int i = 0; i < len; i++)
+ {
+ if (value.Equals(list[i], stringComparison))
+ {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ foreach (string element in source)
+ {
+ if (value.Equals(element, stringComparison))
+ {
+ return true;
+ }
+ }
+
+ return false;
+ }
+ }
+}