mirror of https://github.com/SixLabors/ImageSharp
15 changed files with 1564 additions and 821 deletions
@ -0,0 +1,63 @@ |
|||
// <copyright file="EndianBitConverter.Conversion.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.IO |
|||
{ |
|||
using System; |
|||
|
|||
/// <summary>
|
|||
/// Equivalent of <see cref="BitConverter"/>, but with either endianness.
|
|||
/// </summary>
|
|||
internal abstract partial class EndianBitConverter |
|||
{ |
|||
/// <summary>
|
|||
/// Converts the specified double-precision floating point number to a
|
|||
/// 64-bit signed integer. Note: the endianness of this converter does not
|
|||
/// affect the returned value.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert. </param>
|
|||
/// <returns>A 64-bit signed integer whose value is equivalent to value.</returns>
|
|||
public unsafe long DoubleToInt64Bits(double value) |
|||
{ |
|||
return *((long*)&value); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Converts the specified 64-bit signed integer to a double-precision
|
|||
/// floating point number. Note: the endianness of this converter does not
|
|||
/// affect the returned value.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert. </param>
|
|||
/// <returns>A double-precision floating point number whose value is equivalent to value.</returns>
|
|||
public unsafe double Int64BitsToDouble(long value) |
|||
{ |
|||
return *((double*)&value); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Converts the specified single-precision floating point number to a
|
|||
/// 32-bit signed integer. Note: the endianness of this converter does not
|
|||
/// affect the returned value.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert. </param>
|
|||
/// <returns>A 32-bit signed integer whose value is equivalent to value.</returns>
|
|||
public unsafe int SingleToInt32Bits(float value) |
|||
{ |
|||
return *((int*)&value); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Converts the specified 32-bit signed integer to a single-precision floating point
|
|||
/// number. Note: the endianness of this converter does not
|
|||
/// affect the returned value.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert. </param>
|
|||
/// <returns>A single-precision floating point number whose value is equivalent to value.</returns>
|
|||
public unsafe float Int32BitsToSingle(int value) |
|||
{ |
|||
return *((float*)&value); |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,145 @@ |
|||
// <copyright file="EndianBitConverter.CopyBytes.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.IO |
|||
{ |
|||
using System; |
|||
|
|||
/// <summary>
|
|||
/// Equivalent of <see cref="BitConverter"/>, but with either endianness.
|
|||
/// </summary>
|
|||
internal abstract partial class EndianBitConverter |
|||
{ |
|||
/// <summary>
|
|||
/// Copies the specified 16-bit signed integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public abstract void CopyBytes(short value, byte[] buffer, int index); |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified 32-bit signed integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public abstract void CopyBytes(int value, byte[] buffer, int index); |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified 64-bit signed integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public abstract void CopyBytes(long value, byte[] buffer, int index); |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified 16-bit unsigned integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public void CopyBytes(ushort value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(unchecked((short)value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified 32-bit unsigned integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public void CopyBytes(uint value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(unchecked((int)value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified 64-bit unsigned integer value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public void CopyBytes(ulong value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(unchecked((long)value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified Boolean value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">A Boolean value.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public void CopyBytes(bool value, byte[] buffer, int index) |
|||
{ |
|||
CheckByteArgument(buffer, index, 1); |
|||
buffer[index] = value ? (byte)1 : (byte)0; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified Unicode character value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">A character to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public void CopyBytes(char value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(unchecked((short)value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified double-precision floating point value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public unsafe void CopyBytes(double value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(*((long*)&value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified single-precision floating point value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public unsafe void CopyBytes(float value, byte[] buffer, int index) |
|||
{ |
|||
this.CopyBytes(*((int*)&value), buffer, index); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Copies the specified decimal value into the specified byte array,
|
|||
/// beginning at the specified index.
|
|||
/// </summary>
|
|||
/// <param name="value">A character to convert.</param>
|
|||
/// <param name="buffer">The byte array to copy the bytes into</param>
|
|||
/// <param name="index">The first index into the array to copy the bytes into</param>
|
|||
public unsafe void CopyBytes(decimal value, byte[] buffer, int index) |
|||
{ |
|||
CheckByteArgument(buffer, index, 16); |
|||
|
|||
int* pvalue = (int*)&value; |
|||
this.CopyBytes(pvalue[0], buffer, index); |
|||
this.CopyBytes(pvalue[1], buffer, index + 4); |
|||
this.CopyBytes(pvalue[2], buffer, index + 8); |
|||
this.CopyBytes(pvalue[3], buffer, index + 12); |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,139 @@ |
|||
// <copyright file="EndianBitConverter.GetBytes.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.IO |
|||
{ |
|||
using System; |
|||
|
|||
/// <summary>
|
|||
/// Equivalent of <see cref="BitConverter"/>, but with either endianness.
|
|||
/// </summary>
|
|||
internal abstract partial class EndianBitConverter |
|||
{ |
|||
/// <summary>
|
|||
/// Returns the specified 16-bit signed integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 2.</returns>
|
|||
public byte[] GetBytes(short value) |
|||
{ |
|||
byte[] result = new byte[2]; |
|||
this.CopyBytes(value, result, 0); |
|||
return result; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified 32-bit signed integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 4.</returns>
|
|||
public byte[] GetBytes(int value) |
|||
{ |
|||
byte[] result = new byte[4]; |
|||
this.CopyBytes(value, result, 0); |
|||
return result; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified 64-bit signed integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 8.</returns>
|
|||
public byte[] GetBytes(long value) |
|||
{ |
|||
byte[] result = new byte[8]; |
|||
this.CopyBytes(value, result, 0); |
|||
return result; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified 16-bit unsigned integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 2.</returns>
|
|||
public byte[] GetBytes(ushort value) |
|||
{ |
|||
return this.GetBytes(unchecked((short)value)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified 32-bit unsigned integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 4.</returns>
|
|||
public byte[] GetBytes(uint value) |
|||
{ |
|||
return this.GetBytes(unchecked((int)value)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified 64-bit unsigned integer value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 8.</returns>
|
|||
public byte[] GetBytes(ulong value) |
|||
{ |
|||
return this.GetBytes(unchecked((long)value)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified Boolean value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">A Boolean value.</param>
|
|||
/// <returns>An array of bytes with length 1.</returns>
|
|||
/// <returns>
|
|||
/// The <see cref="T:byte[]"/>.
|
|||
/// </returns>
|
|||
public byte[] GetBytes(bool value) |
|||
{ |
|||
return new byte[1] { value ? (byte)1 : (byte)0 }; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified Unicode character value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">A character to convert.</param>
|
|||
/// <returns>An array of bytes with length 2.</returns>
|
|||
/// <returns>
|
|||
/// The <see cref="T:byte[]"/>.
|
|||
/// </returns>
|
|||
public byte[] GetBytes(char value) |
|||
{ |
|||
return this.GetBytes((short)value); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified double-precision floating point value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 8.</returns>
|
|||
public unsafe byte[] GetBytes(double value) |
|||
{ |
|||
return this.GetBytes(*((long*)&value)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified single-precision floating point value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 4.</returns>
|
|||
public unsafe byte[] GetBytes(float value) |
|||
{ |
|||
return this.GetBytes(*((int*)&value)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns the specified decimal value as an array of bytes.
|
|||
/// </summary>
|
|||
/// <param name="value">The number to convert.</param>
|
|||
/// <returns>An array of bytes with length 16.</returns>
|
|||
public byte[] GetBytes(decimal value) |
|||
{ |
|||
byte[] result = new byte[16]; |
|||
this.CopyBytes(value, result, 0); |
|||
return result; |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,141 @@ |
|||
// <copyright file="EndianBitConverter.ToType.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.IO |
|||
{ |
|||
using System; |
|||
|
|||
/// <summary>
|
|||
/// Equivalent of <see cref="BitConverter"/>, but with either endianness.
|
|||
/// </summary>
|
|||
internal abstract partial class EndianBitConverter |
|||
{ |
|||
/// <summary>
|
|||
/// Returns a 16-bit signed integer converted from two bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 16-bit signed integer formed by two bytes beginning at startIndex.</returns>
|
|||
public abstract short ToInt16(byte[] value, int startIndex); |
|||
|
|||
/// <summary>
|
|||
/// Returns a 32-bit signed integer converted from four bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 32-bit signed integer formed by four bytes beginning at startIndex.</returns>
|
|||
public abstract int ToInt32(byte[] value, int startIndex); |
|||
|
|||
/// <summary>
|
|||
/// Returns a 64-bit signed integer converted from eight bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 64-bit signed integer formed by eight bytes beginning at startIndex.</returns>
|
|||
public abstract long ToInt64(byte[] value, int startIndex); |
|||
|
|||
/// <summary>
|
|||
/// Returns a 16-bit unsigned integer converted from two bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 16-bit unsigned integer formed by two bytes beginning at startIndex.</returns>
|
|||
public ushort ToUInt16(byte[] value, int startIndex) |
|||
{ |
|||
return unchecked((ushort)this.ToInt16(value, startIndex)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a 32-bit unsigned integer converted from four bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 32-bit unsigned integer formed by four bytes beginning at startIndex.</returns>
|
|||
public uint ToUInt32(byte[] value, int startIndex) |
|||
{ |
|||
return unchecked((uint)this.ToInt32(value, startIndex)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a 64-bit unsigned integer converted from eight bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A 64-bit unsigned integer formed by eight bytes beginning at startIndex.</returns>
|
|||
public ulong ToUInt64(byte[] value, int startIndex) |
|||
{ |
|||
return unchecked((ulong)this.ToInt64(value, startIndex)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a Boolean value converted from one byte at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>true if the byte at startIndex in value is nonzero; otherwise, false.</returns>
|
|||
public bool ToBoolean(byte[] value, int startIndex) |
|||
{ |
|||
CheckByteArgument(value, startIndex, 1); |
|||
return value[startIndex] != 0; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a Unicode character converted from two bytes at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A character formed by two bytes beginning at startIndex.</returns>
|
|||
public char ToChar(byte[] value, int startIndex) |
|||
{ |
|||
return unchecked((char)this.ToInt16(value, startIndex)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a double-precision floating point number converted from eight bytes
|
|||
/// at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A double precision floating point number formed by eight bytes beginning at startIndex.</returns>
|
|||
public unsafe double ToDouble(byte[] value, int startIndex) |
|||
{ |
|||
long intValue = this.ToInt64(value, startIndex); |
|||
return *((double*)&intValue); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a single-precision floating point number converted from four bytes
|
|||
/// at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A single precision floating point number formed by four bytes beginning at startIndex.</returns>
|
|||
public unsafe float ToSingle(byte[] value, int startIndex) |
|||
{ |
|||
int intValue = this.ToInt32(value, startIndex); |
|||
return *((float*)&intValue); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Returns a decimal value converted from sixteen bytes
|
|||
/// at a specified position in a byte array.
|
|||
/// </summary>
|
|||
/// <param name="value">An array of bytes.</param>
|
|||
/// <param name="startIndex">The starting position within value.</param>
|
|||
/// <returns>A decimal formed by sixteen bytes beginning at startIndex.</returns>
|
|||
public unsafe decimal ToDecimal(byte[] value, int startIndex) |
|||
{ |
|||
CheckByteArgument(value, startIndex, 16); |
|||
|
|||
decimal result = 0m; |
|||
int* presult = (int*)&result; |
|||
presult[0] = this.ToInt32(value, startIndex); |
|||
presult[1] = this.ToInt32(value, startIndex + 4); |
|||
presult[2] = this.ToInt32(value, startIndex + 8); |
|||
presult[3] = this.ToInt32(value, startIndex + 12); |
|||
return result; |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,230 @@ |
|||
// <copyright file="BigEndianBitConverter.CopyBytesTests.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.Tests.IO |
|||
{ |
|||
using System; |
|||
using ImageSharp.IO; |
|||
using Xunit; |
|||
|
|||
/// <summary>
|
|||
/// The <see cref="BigEndianBitConverter"/> tests.
|
|||
/// </summary>
|
|||
public class BigEndianBitConverterCopyBytesTests |
|||
{ |
|||
[Fact] |
|||
public void CopyToWithNullBufferThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(false, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((short)42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ushort)42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42u, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42L, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ulong)42L, null, 0)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithIndexTooBigThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(false, new byte[1], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((short)42, new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ushort)42, new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42, new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42u, new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42L, new byte[8], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ulong)42L, new byte[8], 1)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithBufferTooSmallThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(false, new byte[0], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((short)42, new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ushort)42, new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42, new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42u, new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes(42L, new byte[7], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.CopyBytes((ulong)42L, new byte[7], 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="bool"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesBoolean() |
|||
{ |
|||
byte[] buffer = new byte[1]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes(false, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(true, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="short"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesShort() |
|||
{ |
|||
byte[] buffer = new byte[2]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes((short)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((short)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((short)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((short)-1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((short)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ushort"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesUShort() |
|||
{ |
|||
byte[] buffer = new byte[2]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes((ushort)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((ushort)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((ushort)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(ushort.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((ushort)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="int"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesInt() |
|||
{ |
|||
byte[] buffer = new byte[4]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes(0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(65536, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(16777216, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(-1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="uint"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesUInt() |
|||
{ |
|||
byte[] buffer = new byte[4]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)65536, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)16777216, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(uint.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes((uint)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="long"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesLong() |
|||
{ |
|||
byte[] buffer = new byte[8]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes(0L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(256L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(65536L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(16777216L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(4294967296L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776L * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776L * 256 * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(-1L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(257L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ulong"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesULong() |
|||
{ |
|||
byte[] buffer = new byte[8]; |
|||
|
|||
EndianBitConverter.BigEndianConverter.CopyBytes(0UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(256UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(65536UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(16777216UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(4294967296UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776UL * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(1099511627776UL * 256 * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(ulong.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.BigEndianConverter.CopyBytes(257UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests the two byte arrays for equality.
|
|||
/// </summary>
|
|||
/// <param name="expected">The expected bytes.</param>
|
|||
/// <param name="actual">The actual bytes.</param>
|
|||
private void CheckBytes(byte[] expected, byte[] actual) |
|||
{ |
|||
Assert.Equal(expected.Length, actual.Length); |
|||
Assert.Equal(expected, actual); |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,158 @@ |
|||
// <copyright file="BigEndianBitConverter.ToTypeTests.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.Tests.IO |
|||
{ |
|||
using System; |
|||
using ImageSharp.IO; |
|||
using Xunit; |
|||
|
|||
/// <summary>
|
|||
/// The <see cref="BigEndianBitConverter"/> tests.
|
|||
/// </summary>
|
|||
public class BigEndianBitConverterTests |
|||
{ |
|||
[Fact] |
|||
public void CopyToWithNullBufferThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToBoolean(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToInt16(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToUInt16(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToInt32(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToUInt32(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToInt64(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.BigEndianConverter.ToUInt64(null, 0)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithIndexTooBigThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToBoolean(new byte[1], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt16(new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt16(new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt32(new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt32(new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt64(new byte[8], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt64(new byte[8], 1)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithBufferTooSmallThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToBoolean(new byte[0], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt16(new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt16(new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt32(new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt32(new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToInt64(new byte[7], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.BigEndianConverter.ToUInt64(new byte[7], 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="bool"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToBoolean() |
|||
{ |
|||
Assert.Equal(false, EndianBitConverter.BigEndianConverter.ToBoolean(new byte[] { 0 }, 0)); |
|||
Assert.Equal(true, EndianBitConverter.BigEndianConverter.ToBoolean(new byte[] { 1 }, 0)); |
|||
Assert.Equal(true, EndianBitConverter.BigEndianConverter.ToBoolean(new byte[] { 42 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="short"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt16() |
|||
{ |
|||
Assert.Equal((short)0, EndianBitConverter.BigEndianConverter.ToInt16(new byte[] { 0, 0 }, 0)); |
|||
Assert.Equal((short)1, EndianBitConverter.BigEndianConverter.ToInt16(new byte[] { 0, 1 }, 0)); |
|||
Assert.Equal((short)256, EndianBitConverter.BigEndianConverter.ToInt16(new byte[] { 1, 0 }, 0)); |
|||
Assert.Equal((short)-1, EndianBitConverter.BigEndianConverter.ToInt16(new byte[] { 255, 255 }, 0)); |
|||
Assert.Equal((short)257, EndianBitConverter.BigEndianConverter.ToInt16(new byte[] { 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ushort"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToUInt16() |
|||
{ |
|||
Assert.Equal((ushort)0, EndianBitConverter.BigEndianConverter.ToUInt16(new byte[] { 0, 0 }, 0)); |
|||
Assert.Equal((ushort)1, EndianBitConverter.BigEndianConverter.ToUInt16(new byte[] { 0, 1 }, 0)); |
|||
Assert.Equal((ushort)256, EndianBitConverter.BigEndianConverter.ToUInt16(new byte[] { 1, 0 }, 0)); |
|||
Assert.Equal(ushort.MaxValue, EndianBitConverter.BigEndianConverter.ToUInt16(new byte[] { 255, 255 }, 0)); |
|||
Assert.Equal((ushort)257, EndianBitConverter.BigEndianConverter.ToUInt16(new byte[] { 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="int"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt32() |
|||
{ |
|||
Assert.Equal(0, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(256, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(65536, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(16777216, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(-1, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257, EndianBitConverter.BigEndianConverter.ToInt32(new byte[] { 0, 0, 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="uint"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToUInt32() |
|||
{ |
|||
Assert.Equal((uint)0, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal((uint)1, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal((uint)256, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal((uint)65536, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal((uint)16777216, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(uint.MaxValue, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal((uint)257, EndianBitConverter.BigEndianConverter.ToUInt32(new byte[] { 0, 0, 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="long"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt64() |
|||
{ |
|||
Assert.Equal(0L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(256L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(65536L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(16777216L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(4294967296L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776L * 256, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776L * 256 * 256, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(-1L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257L, EndianBitConverter.BigEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ulong"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void GetBytesULong() |
|||
{ |
|||
Assert.Equal(0UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(256UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(65536UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(16777216UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(4294967296UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL * 256, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL * 256 * 256, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(ulong.MaxValue, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257UL, EndianBitConverter.BigEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 1 }, 0)); |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,230 @@ |
|||
// <copyright file="LittleEndianBitConverter.CopyBytesTests.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.Tests.IO |
|||
{ |
|||
using System; |
|||
using ImageSharp.IO; |
|||
using Xunit; |
|||
|
|||
/// <summary>
|
|||
/// The <see cref="LittleEndianBitConverter"/> tests.
|
|||
/// </summary>
|
|||
public class LittleEndianBitConverterCopyBytesTests |
|||
{ |
|||
[Fact] |
|||
public void CopyToWithNullBufferThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(false, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((short)42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42u, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42L, null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ulong)42L, null, 0)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithIndexTooBigThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(false, new byte[1], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((short)42, new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)42, new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42, new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42u, new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42L, new byte[8], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ulong)42L, new byte[8], 1)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithBufferTooSmallThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(false, new byte[0], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((short)42, new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)42, new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42, new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42u, new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes(42L, new byte[7], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.CopyBytes((ulong)42L, new byte[7], 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="bool"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesBoolean() |
|||
{ |
|||
byte[] buffer = new byte[1]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(false, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(true, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="short"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesShort() |
|||
{ |
|||
byte[] buffer = new byte[2]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((short)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((short)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((short)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((short)-1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((short)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ushort"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesUShort() |
|||
{ |
|||
byte[] buffer = new byte[2]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(ushort.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((ushort)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="int"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesInt() |
|||
{ |
|||
byte[] buffer = new byte[4]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(65536, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(16777216, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(-1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1, 0, 0 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="uint"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesUInt() |
|||
{ |
|||
byte[] buffer = new byte[4]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)0, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)1, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)65536, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)16777216, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(uint.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes((uint)257, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1, 0, 0 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="long"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesLong() |
|||
{ |
|||
byte[] buffer = new byte[8]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(0L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(256L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(65536L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(16777216L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(4294967296L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776L * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776L * 256 * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(-1L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(257L, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ulong"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void CopyBytesULong() |
|||
{ |
|||
byte[] buffer = new byte[8]; |
|||
|
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(0UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(256UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(65536UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(16777216UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(4294967296UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776UL * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(1099511627776UL * 256 * 256, buffer, 0); |
|||
this.CheckBytes(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(ulong.MaxValue, buffer, 0); |
|||
this.CheckBytes(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, buffer); |
|||
EndianBitConverter.LittleEndianConverter.CopyBytes(257UL, buffer, 0); |
|||
this.CheckBytes(new byte[] { 1, 1, 0, 0, 0, 0, 0, 0 }, buffer); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests the two byte arrays for equality.
|
|||
/// </summary>
|
|||
/// <param name="expected">The expected bytes.</param>
|
|||
/// <param name="actual">The actual bytes.</param>
|
|||
private void CheckBytes(byte[] expected, byte[] actual) |
|||
{ |
|||
Assert.Equal(expected.Length, actual.Length); |
|||
Assert.Equal(expected, actual); |
|||
} |
|||
} |
|||
} |
|||
@ -0,0 +1,157 @@ |
|||
// <copyright file="LittleEndianBitConverter.ToTypeTests.cs" company="James Jackson-South">
|
|||
// Copyright (c) James Jackson-South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageSharp.Tests.IO |
|||
{ |
|||
using System; |
|||
using ImageSharp.IO; |
|||
using Xunit; |
|||
|
|||
/// <summary>
|
|||
/// The <see cref="LittleEndianBitConverter"/> tests.
|
|||
/// </summary>
|
|||
public class LittleEndianBitConverterToTypeTests |
|||
{ |
|||
[Fact] |
|||
public void CopyToWithNullBufferThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToBoolean(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToInt16(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToUInt16(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToInt32(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToUInt32(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToInt64(null, 0)); |
|||
Assert.Throws<ArgumentNullException>(() => EndianBitConverter.LittleEndianConverter.ToUInt64(null, 0)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithIndexTooBigThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToBoolean(new byte[1], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt16(new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[2], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt32(new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[4], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt64(new byte[8], 1)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[8], 1)); |
|||
} |
|||
|
|||
[Fact] |
|||
public void CopyToWithBufferTooSmallThrowsException() |
|||
{ |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToBoolean(new byte[0], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt16(new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[1], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt32(new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[3], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToInt64(new byte[7], 0)); |
|||
Assert.Throws<ArgumentOutOfRangeException>(() => EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[7], 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="bool"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToBoolean() |
|||
{ |
|||
Assert.Equal(false, EndianBitConverter.LittleEndianConverter.ToBoolean(new byte[] { 0 }, 0)); |
|||
Assert.Equal(true, EndianBitConverter.LittleEndianConverter.ToBoolean(new byte[] { 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="short"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt16() |
|||
{ |
|||
Assert.Equal((short)0, EndianBitConverter.LittleEndianConverter.ToInt16(new byte[] { 0, 0 }, 0)); |
|||
Assert.Equal((short)1, EndianBitConverter.LittleEndianConverter.ToInt16(new byte[] { 1, 0 }, 0)); |
|||
Assert.Equal((short)256, EndianBitConverter.LittleEndianConverter.ToInt16(new byte[] { 0, 1 }, 0)); |
|||
Assert.Equal((short)-1, EndianBitConverter.LittleEndianConverter.ToInt16(new byte[] { 255, 255 }, 0)); |
|||
Assert.Equal((short)257, EndianBitConverter.LittleEndianConverter.ToInt16(new byte[] { 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ushort"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToUInt16() |
|||
{ |
|||
Assert.Equal((ushort)0, EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[] { 0, 0 }, 0)); |
|||
Assert.Equal((ushort)1, EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[] { 1, 0 }, 0)); |
|||
Assert.Equal((ushort)256, EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[] { 0, 1 }, 0)); |
|||
Assert.Equal(ushort.MaxValue, EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[] { 255, 255 }, 0)); |
|||
Assert.Equal((ushort)257, EndianBitConverter.LittleEndianConverter.ToUInt16(new byte[] { 1, 1 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="int"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt32() |
|||
{ |
|||
Assert.Equal(0, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(256, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(65536, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(16777216, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(-1, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257, EndianBitConverter.LittleEndianConverter.ToInt32(new byte[] { 1, 1, 0, 0 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="uint"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToUInt32() |
|||
{ |
|||
Assert.Equal((uint)0, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal((uint)1, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal((uint)256, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal((uint)65536, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal((uint)16777216, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(uint.MaxValue, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal((uint)257, EndianBitConverter.LittleEndianConverter.ToUInt32(new byte[] { 1, 1, 0, 0 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="long"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToInt64() |
|||
{ |
|||
Assert.Equal(0L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(256L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(65536L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(16777216L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(4294967296L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776L * 256, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(1099511627776L * 256 * 256, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(-1L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257L, EndianBitConverter.LittleEndianConverter.ToInt64(new byte[] { 1, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// Tests that passing a <see cref="ulong"/> returns the correct bytes.
|
|||
/// </summary>
|
|||
[Fact] |
|||
public void ToUInt64() |
|||
{ |
|||
Assert.Equal(0UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 1, 0, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(256UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(65536UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 1, 0, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(16777216UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 1, 0, 0, 0, 0 }, 0)); |
|||
Assert.Equal(4294967296UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 1, 0, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 1, 0, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL * 256, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 1, 0 }, 0)); |
|||
Assert.Equal(1099511627776UL * 256 * 256, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 0, 0, 0, 0, 0, 0, 0, 1 }, 0)); |
|||
Assert.Equal(ulong.MaxValue, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 255, 255, 255, 255, 255, 255, 255, 255 }, 0)); |
|||
Assert.Equal(257UL, EndianBitConverter.LittleEndianConverter.ToUInt64(new byte[] { 1, 1, 0, 0, 0, 0, 0, 0 }, 0)); |
|||
} |
|||
} |
|||
} |
|||
Loading…
Reference in new issue