-
Notifications
You must be signed in to change notification settings - Fork 0
/
Extensions.cs
79 lines (76 loc) · 3.03 KB
/
Extensions.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
This file is part of MqttSql (Copyright © 2024 Guiorgy).
MqttSql is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
MqttSql is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with MqttSql. If not, see <https://www.gnu.org/licenses/>.
*/
using System.Collections.Generic;
using System.Linq;
namespace MqttSql
{
public static class Extensions
{
//
// Summary:
// Determines whether a sequence contains any of the specified elements
// by using the default equality comparer.
//
// Parameters:
// source:
// A sequence in which to locate a value.
//
// values:
// The values to locate in the sequence.
//
// Type parameters:
// TSource:
// The type of the elements of source.
//
// Returns:
// true if the source sequence contains an element that has any of the
// specified values; otherwise, false.
//
// Exceptions:
// T:System.ArgumentNullException:
// source or values is null.
public static bool ContainsAny<TSource>(this IEnumerable<TSource> source, IEnumerable<TSource> values)
{
return source.Intersect(values).Any();
}
public static bool ContainsAny<TSource>(this IEnumerable<TSource> source, params TSource[] values)
{
return source.Intersect(values).Any();
}
//
// Summary:
// Determines whether a sequence contains all of the specified elements
// by using the default equality comparer.
//
// Parameters:
// source:
// A sequence in which to locate a value.
//
// values:
// The values to locate in the sequence.
//
// Type parameters:
// TSource:
// The type of the elements of source.
//
// Returns:
// true if the source sequence contains elements that have the specified
// values; otherwise, false.
//
// Exceptions:
// T:System.ArgumentNullException:
// source or values is null.
public static bool ContainsAal<TSource>(this IEnumerable<TSource> source, IEnumerable<TSource> values)
{
return source.Intersect(values).Count() == values.Count();
}
public static bool ContainsAal<TSource>(this IEnumerable<TSource> source, params TSource[] values)
{
return source.Intersect(values).Count() == values.Count();
}
}
}