Extension methods on primitives types for various binary operations, such as reading and writing values from bytes and calculating parity.
The name is based on the BinaryPrimitives class in the .NET Framework which provides similar methods.
Full documentation is available at mrkwatkins.github.io/BinaryPrimitives. Source code and issue tracking are on GitHub.
dotnet add package MrKWatkins.BinaryPrimitives
Read and write multi-byte integers from byte[], Span<byte>, Stream, and other byte
container types. All methods support an optional Endian parameter (defaulting to
Endian.Little):
byte[] data = new byte[8];
data.SetInt32(0, 42);
data.SetUInt16(4, 1000, Endian.Big);
int a = data.GetInt32(0); // 42
ushort b = data.GetUInt16(4, Endian.Big); // 1000Collections can have values appended directly:
var buffer = new List<byte>();
buffer.AddUInt32(0xDEADBEEF);
buffer.AddInt16(-1, Endian.Big);Streams support typed reading and writing, with async overloads for all methods:
stream.WriteInt32(42);
int value = stream.ReadInt32OrThrow();Get, set, and clear individual bits or ranges of bits on byte, ushort, int, uint,
long, and ulong:
byte b = 0b00001010;
bool set = b.GetBit(1); // true
byte with0 = b.SetBit(0); // 0b00001011
byte clear = b.ResetBit(1); // 0b00001000
byte range = b.GetBits(1, 3); // bits 1..3, shifted to position 0byte also provides nibble access, parity, and CPU flag detection:
byte high = b.HighNibble(); // bits 4-7
bool even = b.Parity(); // true if an even number of bits are setAll supported integer types can be formatted as a binary string:
string s = ((byte)0x5A).ToBinaryString(); // "0b01011010"ReadOnlyListStream wraps an IReadOnlyList<byte> as a seekable, read-only Stream:
IReadOnlyList<byte> bytes = LoadBytes();
using var stream = new ReadOnlyListStream(bytes);PeekableStream wraps any readable Stream to add one-byte lookahead without consuming the
byte:
using var stream = new PeekableStream(inner);
if (stream.Peek() == 0xFF)
{
stream.ReadByteOrThrow(); // consume it
}Licensed under GPL v3.0.