mirror of
https://github.com/chylex/.NET-Community-Toolkit.git
synced 2024-11-25 01:42:46 +01:00
1825 lines
96 KiB
C#
1825 lines
96 KiB
C#
// Licensed to the .NET Foundation under one or more agreements.
|
|
// The .NET Foundation licenses this file to you under the MIT license.
|
|
// See the LICENSE file in the project root for more information.
|
|
// =====================
|
|
// Auto generated file
|
|
// =====================
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Runtime.CompilerServices;
|
|
|
|
namespace CommunityToolkit.Diagnostics;
|
|
|
|
/// <inheritdoc/>
|
|
partial class Guard
|
|
{
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(Span<T> span, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(Span<T> span, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmptyWithSpan<T>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Span{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(Span<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="Span{T}"/> instance must have the same size of a destination <see cref="Span{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(Span<T> source, Span<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length == destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="Span{T}"/> instance must have a size of less than or equal to that of a destination <see cref="Span{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="Span{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(Span<T> source, Span<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length <= destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="Span{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="span"/>.</param>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="span"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, Span<T> span, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)span.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="Span{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Span{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="span"/>.</param>
|
|
/// <param name="span">The input <see cref="Span{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="span"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, Span<T> span, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)span.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(ReadOnlySpan<T> span, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(ReadOnlySpan<T> span, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmptyWithReadOnlySpan<T>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlySpan{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="span"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ReadOnlySpan<T> span, int size, [CallerArgumentExpression("span")] string name = "")
|
|
{
|
|
if (span.Length <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(span, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ReadOnlySpan{T}"/> instance must have the same size of a destination <see cref="ReadOnlySpan{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ReadOnlySpan<T> source, Span<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length == destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ReadOnlySpan{T}"/> instance must have a size of less than or equal to that of a destination <see cref="ReadOnlySpan{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ReadOnlySpan{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ReadOnlySpan<T> source, Span<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length <= destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="ReadOnlySpan{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="span"/>.</param>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="span"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, ReadOnlySpan<T> span, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)span.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="ReadOnlySpan{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlySpan{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="span"/>.</param>
|
|
/// <param name="span">The input <see cref="ReadOnlySpan{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="span"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, ReadOnlySpan<T> span, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)span.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, span, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(Memory<T> memory, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(Memory<T> memory, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<Memory<T>>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="Memory{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(Memory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="Memory{T}"/> instance must have the same size of a destination <see cref="Memory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(Memory<T> source, Memory<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length == destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="Memory{T}"/> instance must have a size of less than or equal to that of a destination <see cref="Memory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="Memory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(Memory<T> source, Memory<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length <= destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="Memory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="memory"/>.</param>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="memory"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, Memory<T> memory, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)memory.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="Memory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="Memory{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="memory"/>.</param>
|
|
/// <param name="memory">The input <see cref="Memory{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="memory"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, Memory<T> memory, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)memory.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(ReadOnlyMemory<T> memory, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(ReadOnlyMemory<T> memory, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<ReadOnlyMemory<T>>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ReadOnlyMemory{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="memory"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ReadOnlyMemory<T> memory, int size, [CallerArgumentExpression("memory")] string name = "")
|
|
{
|
|
if (memory.Length <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(memory, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ReadOnlyMemory{T}"/> instance must have the same size of a destination <see cref="ReadOnlyMemory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ReadOnlyMemory<T> source, Memory<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length == destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ReadOnlyMemory{T}"/> instance must have a size of less than or equal to that of a destination <see cref="ReadOnlyMemory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ReadOnlyMemory{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ReadOnlyMemory<T> source, Memory<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length <= destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="ReadOnlyMemory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="memory"/>.</param>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="memory"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, ReadOnlyMemory<T> memory, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)memory.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="ReadOnlyMemory{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ReadOnlyMemory{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="memory"/>.</param>
|
|
/// <param name="memory">The input <see cref="ReadOnlyMemory{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="memory"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, ReadOnlyMemory<T> memory, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)memory.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, memory, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(T[] array, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(array, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(T[] array, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<T[]>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see typeparamref="T"/> array instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="array"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(T[] array, int size, [CallerArgumentExpression("array")] string name = "")
|
|
{
|
|
if (array.Length <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(array, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see typeparamref="T"/> array instance must have the same size of a destination <see typeparamref="T"/> array instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="source">The source <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(T[] source, T[] destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length == destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see typeparamref="T"/> array instance must have a size of less than or equal to that of a destination <see typeparamref="T"/> array instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="source">The source <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see typeparamref="T"/> array instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(T[] source, T[] destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Length <= destination.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(source, destination, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see typeparamref="T"/> array instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="array"/>.</param>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="array"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, T[] array, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)array.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, array, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see typeparamref="T"/> array instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see typeparamref="T"/> array instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="array"/>.</param>
|
|
/// <param name="array">The input <see typeparamref="T"/> array instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="array"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, T[] array, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)array.Length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, array, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(List<T> list, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty((ICollection<T>)list, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(List<T> list, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<List<T>>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="List{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="list"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(List<T> list, int size, [CallerArgumentExpression("list")] string name = "")
|
|
{
|
|
if (list.Count <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo((ICollection<T>)list, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="List{T}"/> instance must have the same size of a destination <see cref="List{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(List<T> source, List<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count == destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo((ICollection<T>)source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="List{T}"/> instance must have a size of less than or equal to that of a destination <see cref="List{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="List{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(List<T> source, List<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count <= destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo((ICollection<T>)source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="List{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="list"/>.</param>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="list"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, List<T> list, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)list.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, (ICollection<T>)list, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="List{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="List{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="list"/>.</param>
|
|
/// <param name="list">The input <see cref="List{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="list"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, List<T> list, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)list.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, (ICollection<T>)list, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(ICollection<T> collection, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(collection, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(ICollection<T> collection, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<ICollection<T>>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="ICollection{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ICollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ICollection{T}"/> instance must have the same size of a destination <see cref="ICollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(ICollection<T> source, ICollection<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count == destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="ICollection{T}"/> instance must have a size of less than or equal to that of a destination <see cref="ICollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="ICollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(ICollection<T> source, ICollection<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count <= destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="ICollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="collection"/>.</param>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="collection"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, ICollection<T> collection, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)collection.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, collection, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="ICollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="ICollection{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="collection"/>.</param>
|
|
/// <param name="collection">The input <see cref="ICollection{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="collection"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, ICollection<T> collection, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)collection.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, collection, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is != 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsEmpty<T>(IReadOnlyCollection<T> collection, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count == 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsEmpty(collection, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must not be empty.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is == 0.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotEmpty<T>(IReadOnlyCollection<T> collection, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count != 0)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForIsNotEmpty<IReadOnlyCollection<T>>(name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size of a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is != <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count == size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size not equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is == <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeNotEqualTo<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count != size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeNotEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size over a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is <= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThan<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count > size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThan(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size of at least or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is < <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeGreaterThanOrEqualTo<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count >= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeGreaterThanOrEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size of less than a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is >= <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThan<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count < size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThan(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input <see cref="IReadOnlyCollection{T}"/> instance must have a size of less than or equal to a specified value.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="size">The target size to test.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="collection"/> is > <paramref name="size"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(IReadOnlyCollection<T> collection, int size, [CallerArgumentExpression("collection")] string name = "")
|
|
{
|
|
if (collection.Count <= size)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeLessThanOrEqualTo(collection, size, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="IReadOnlyCollection{T}"/> instance must have the same size of a destination <see cref="IReadOnlyCollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is != the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeEqualTo<T>(IReadOnlyCollection<T> source, ICollection<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count == destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the source <see cref="IReadOnlyCollection{T}"/> instance must have a size of less than or equal to that of a destination <see cref="IReadOnlyCollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="source">The source <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="destination">The destination <see cref="IReadOnlyCollection{T}"/> instance to check the size for.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentException">Thrown if the size of <paramref name="source"/> is > the one of <paramref name="destination"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void HasSizeLessThanOrEqualTo<T>(IReadOnlyCollection<T> source, ICollection<T> destination, [CallerArgumentExpression("source")] string name = "")
|
|
{
|
|
if (source.Count <= destination.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentExceptionForHasSizeEqualTo(source, destination.Count, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is valid for a given <see cref="IReadOnlyCollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="collection"/>.</param>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is not valid to access <paramref name="collection"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsInRangeFor<T>(int index, IReadOnlyCollection<T> collection, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index < (uint)collection.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsInRangeFor(index, collection, name);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Asserts that the input index is not valid for a given <see cref="IReadOnlyCollection{T}"/> instance.
|
|
/// </summary>
|
|
/// <typeparam name="T">The item of items in the input <see cref="IReadOnlyCollection{T}"/> instance.</typeparam>
|
|
/// <param name="index">The input index to be used to access <paramref name="collection"/>.</param>
|
|
/// <param name="collection">The input <see cref="IReadOnlyCollection{T}"/> instance to use to validate <paramref name="index"/>.</param>
|
|
/// <param name="name">The name of the input parameter being tested.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">Thrown if <paramref name="index"/> is valid to access <paramref name="collection"/>.</exception>
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
|
public static void IsNotInRangeFor<T>(int index, IReadOnlyCollection<T> collection, [CallerArgumentExpression("index")] string name = "")
|
|
{
|
|
if ((uint)index >= (uint)collection.Count)
|
|
{
|
|
return;
|
|
}
|
|
|
|
ThrowHelper.ThrowArgumentOutOfRangeExceptionForIsNotInRangeFor(index, collection, name);
|
|
}
|
|
}
|