-
Notifications
You must be signed in to change notification settings - Fork 91
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into users/ferojo/alignVerification
- Loading branch information
Showing
66 changed files
with
5,858 additions
and
605 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
63 changes: 63 additions & 0 deletions
63
src/Microsoft.ComponentDetection.Contracts/ConcurrentHashSet.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
namespace Microsoft.ComponentDetection.Contracts; | ||
|
||
using System.Collections; | ||
using System.Collections.Concurrent; | ||
using System.Collections.Generic; | ||
|
||
/// <summary>Represents a thread-safe set of values.</summary> | ||
/// <typeparam name="T">The type of elements in the hash set.</typeparam> | ||
public class ConcurrentHashSet<T> : IEnumerable<T> | ||
{ | ||
private readonly ConcurrentDictionary<T, byte> dictionary; | ||
|
||
// Create different constructors for different equality comparers | ||
public ConcurrentHashSet() => this.dictionary = new ConcurrentDictionary<T, byte>(); | ||
|
||
public ConcurrentHashSet(IEqualityComparer<T> comparer) => this.dictionary = new ConcurrentDictionary<T, byte>(comparer); | ||
|
||
/// <summary>Adds the specific element to the <see cref="ConcurrentHashSet{T}"/> object.</summary> | ||
/// <param name="item">The element to add to the set.</param> | ||
/// <returns>true if element was added to <see cref="ConcurrentHashSet{T}"/> object; false, if item was already present.</returns> | ||
public bool Add(T item) | ||
{ | ||
return this.dictionary.TryAdd(item, 0); | ||
} | ||
|
||
/// <summary>Removes the specific element to the <see cref="ConcurrentHashSet{T}"/> object.</summary> | ||
/// <param name="item">The element to be removed from the set.</param> | ||
/// <returns>true if element was successfully found and removed; otherwise, false.</returns> | ||
public bool Remove(T item) | ||
{ | ||
return this.dictionary.TryRemove(item, out _); | ||
} | ||
|
||
/// <summary>Determines whether the <see cref="ConcurrentHashSet{T}"/> contains the specified element.</summary> | ||
/// <param name="item">The element to locate in the <see cref="ConcurrentHashSet{T}"/> object.</param> | ||
/// <returns>true if the <see cref="ConcurrentHashSet{T}"/> object contains the specified element; otherwise, false.</returns> | ||
public bool Contains(T item) | ||
{ | ||
return this.dictionary.ContainsKey(item); | ||
} | ||
|
||
/// <summary>Removes all elements from a <see cref="ConcurrentHashSet{T}"/> object.</summary> | ||
public void Clear() => this.dictionary.Clear(); | ||
|
||
public ISet<T> ToHashSet() | ||
{ | ||
return new HashSet<T>(this.dictionary.Keys); | ||
} | ||
|
||
/// <summary>Returns an enumerator that iterates through the <see cref="ConcurrentHashSet{T}"/>.</summary> | ||
/// <returns>An enumerator for the <see cref="ConcurrentHashSet{T}"/>.</returns> | ||
public IEnumerator<T> GetEnumerator() | ||
{ | ||
return this.dictionary.Keys.GetEnumerator(); | ||
} | ||
|
||
/// <summary>Returns an enumerator that iterates through the <see cref="ConcurrentHashSet{T}"/>.</summary> | ||
/// <returns>An enumerator for the <see cref="ConcurrentHashSet{T}"/>.</returns> | ||
IEnumerator IEnumerable.GetEnumerator() | ||
{ | ||
return this.GetEnumerator(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.