Add misc helper functions and fix null assertion text

This commit is contained in:
Alex Barney 2021-07-11 22:37:44 -07:00
parent ec6eff156c
commit f444a999ba
3 changed files with 64 additions and 4 deletions

View file

@ -4,6 +4,33 @@ using System.Runtime.InteropServices;
namespace LibHac.Common namespace LibHac.Common
{ {
public static class SpanExtensions
{
/// <summary>
/// Gets the element at the specified zero-based index or gets 0 if the index is out-of-bounds.
/// </summary>
/// <param name="span">The <see cref="ReadOnlySpan{T}"/> containing the element to get.</param>
/// <param name="i">The zero-based index of the element.</param>
/// <returns>The element at the specified index or 0 if out-of-bounds.</returns>
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static byte At(in this ReadOnlySpan<byte> span, int i)
{
return (uint)i >= (uint)span.Length ? (byte)0 : span[i];
}
/// <summary>
/// Gets the element at the specified zero-based index or gets 0 if the index is out-of-bounds.
/// </summary>
/// <param name="span">The <see cref="Span{T}"/> containing the element to get.</param>
/// <param name="i">The zero-based index of the element.</param>
/// <returns>The element at the specified index or 0 if out-of-bounds.</returns>
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static byte At(in this Span<byte> span, int i)
{
return (uint)i >= (uint)span.Length ? (byte)0 : span[i];
}
}
public static class SpanHelpers public static class SpanHelpers
{ {
[MethodImpl(MethodImplOptions.AggressiveInlining)] [MethodImpl(MethodImplOptions.AggressiveInlining)]

View file

@ -10,14 +10,14 @@ namespace LibHac.Diag.Impl
internal static void InvokeAssertionNotNull(AssertionType assertionType, string valueText, string functionName, internal static void InvokeAssertionNotNull(AssertionType assertionType, string valueText, string functionName,
string fileName, int lineNumber) string fileName, int lineNumber)
{ {
Assert.OnAssertionFailure(assertionType, valueText, functionName, fileName, lineNumber, Assert.OnAssertionFailure(assertionType, "NotNull", functionName, fileName, lineNumber,
$"{valueText} must not be nullptr."); $"{valueText} must not be nullptr.");
} }
internal static void InvokeAssertionNull(AssertionType assertionType, string valueText, string functionName, internal static void InvokeAssertionNull(AssertionType assertionType, string valueText, string functionName,
string fileName, int lineNumber) string fileName, int lineNumber)
{ {
Assert.OnAssertionFailure(assertionType, valueText, functionName, fileName, lineNumber, Assert.OnAssertionFailure(assertionType, "Null", functionName, fileName, lineNumber,
$"{valueText} must be nullptr."); $"{valueText} must be nullptr.");
} }
@ -137,12 +137,12 @@ namespace LibHac.Diag.Impl
public static bool NotNull<T>(Span<T> span) public static bool NotNull<T>(Span<T> span)
{ {
return !Unsafe.IsNullRef(ref MemoryMarshal.GetReference(span)); return !Unsafe.IsNullRef(ref MemoryMarshal.GetReference(span)) || span.Length == 0;
} }
public static bool NotNull<T>(ReadOnlySpan<T> span) public static bool NotNull<T>(ReadOnlySpan<T> span)
{ {
return !Unsafe.IsNullRef(ref MemoryMarshal.GetReference(span)); return !Unsafe.IsNullRef(ref MemoryMarshal.GetReference(span)) || span.Length == 0;
} }
public static bool WithinRange(int value, int lowerInclusive, int upperExclusive) public static bool WithinRange(int value, int lowerInclusive, int upperExclusive)

View file

@ -22,6 +22,22 @@ namespace LibHac.Util
return i; return i;
} }
public static int Copy(Span<byte> dest, ReadOnlySpan<byte> source, int maxLen)
{
int maxLenLocal = Math.Min(Math.Min(dest.Length, source.Length), maxLen);
int i;
for (i = 0; i < maxLenLocal && source[i] != 0; i++)
dest[i] = source[i];
if (i < dest.Length)
{
dest[i] = 0;
}
return i;
}
public static int GetLength(ReadOnlySpan<byte> s) public static int GetLength(ReadOnlySpan<byte> s)
{ {
int i = 0; int i = 0;
@ -160,6 +176,23 @@ namespace LibHac.Util
return iDest; return iDest;
} }
public static int Find(ReadOnlySpan<byte> haystack, ReadOnlySpan<byte> needle)
{
if (needle.Length == 0)
return 0;
for (int i = 0; i <= haystack.Length - needle.Length; i++)
{
int j;
for (j = 0; j < needle.Length && haystack[i + j] == needle[j]; j++) { }
if (j == needle.Length)
return i;
}
return -1;
}
public static ReadOnlySpan<byte> StringToUtf8(string value) public static ReadOnlySpan<byte> StringToUtf8(string value)
{ {
return Encoding.UTF8.GetBytes(value).AsSpan(); return Encoding.UTF8.GetBytes(value).AsSpan();