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);
}
}
}
}