Firstborn/Library/PackageCache/com.unity.inputsystem@1.5.1/InputSystem/Utilities/DynamicBitfield.cs

60 lines
1.7 KiB
C#
Raw Normal View History

2023-03-28 13:24:16 -04:00
using UnityEngine.InputSystem.Utilities;
namespace UnityEngine.InputSystem
{
/// <summary>
/// Struct replacement for System.Collections.Bitfield.
/// </summary>
/// <remarks>
/// We don't want the extra heap object just for keeping the header
/// state of the bitfield. This struct directly embeds the header
/// into the owner. Also doesn't allocate any array while length is
/// less than or equal to 64 bits.
/// </remarks>
internal struct DynamicBitfield
{
public InlinedArray<ulong> array;
public int length;
public void SetLength(int newLength)
{
// Don't touch array size if we don't have to. We're fine having a
// larger array to work with if it's already in place.
var ulongCount = BitCountToULongCount(newLength);
if (array.length < ulongCount)
array.SetLength(ulongCount);
length = newLength;
}
public void SetBit(int bitIndex)
{
Debug.Assert(bitIndex >= 0);
Debug.Assert(bitIndex < length);
array[bitIndex / 64] |= 1UL << (bitIndex % 64);
}
public bool TestBit(int bitIndex)
{
Debug.Assert(bitIndex >= 0);
Debug.Assert(bitIndex < length);
return (array[bitIndex / 64] & (1UL << (bitIndex % 64))) != 0;
}
public void ClearBit(int bitIndex)
{
Debug.Assert(bitIndex >= 0);
Debug.Assert(bitIndex < length);
array[bitIndex / 64] &= ~(1UL << (bitIndex % 64));
}
private static int BitCountToULongCount(int bitCount)
{
return (bitCount + 63) / 64;
}
}
}