using System; using Unity.Collections.LowLevel.Unsafe; namespace Unity.Collections { /// /// Provides extension methods for sets. /// public unsafe static class HashSetExtensions { /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, FixedList128Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, FixedList128Bytes other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, FixedList128Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, FixedList32Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, FixedList32Bytes other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, FixedList32Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, FixedList4096Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, FixedList4096Bytes other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, FixedList4096Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, FixedList512Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, FixedList512Bytes other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, FixedList512Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, FixedList64Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, FixedList64Bytes other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, FixedList64Bytes other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, NativeArray other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, NativeArray other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, NativeArray other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, NativeParallelHashSet other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, NativeParallelHashSet other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, NativeParallelHashSet other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } /// /// Removes the values from this set which are also present in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void ExceptWith(this NativeParallelHashSet container, NativeList other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Remove(item); } } /// /// Removes the values from this set which are absent in another collection. /// /// The type of values. /// The set to remove values from. /// The collection to compare with. public static void IntersectWith(this NativeParallelHashSet container, NativeList other) where T : unmanaged, IEquatable { var result = new UnsafeList(container.Count(), Allocator.Temp); foreach (var item in other) { if (container.Contains(item)) { result.Add(item); } } container.Clear(); container.UnionWith(result); result.Dispose(); } /// /// Adds all values from a collection to this set. /// /// The type of values. /// The set to add values to. /// The collection to copy values from. public static void UnionWith(this NativeParallelHashSet container, NativeList other) where T : unmanaged, IEquatable { foreach (var item in other) { container.Add(item); } } } }