Rasagar/Library/PackageCache/com.unity.collections/Unity.Collections/FixedStringFormatMethods.gen.cs
2024-08-26 23:07:20 +03:00

946 lines
54 KiB
C#

//------------------------------------------------------------------------------
// <auto-generated>
// This code was generated by a tool.
//
// TextTransform Samples/Packages/com.unity.collections/Unity.Collections/FixedStringFormatMethods.tt
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------
using System;
using Unity.Collections.LowLevel.Unsafe;
namespace Unity.Collections
{
/// <summary>
/// Provides extension methods for FixedString*N*Bytes.
/// </summary>
public unsafe static partial class FixedStringMethods
{
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/) })]
public static unsafe FormatError AppendFormat<T, U, T0>(ref this T dest, in U format, in T0 arg0)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1>(ref this T dest, in U format, in T0 arg0, in T1 arg1)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T5">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg5">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/), typeof(FixedString128Bytes /*T5*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4, T5>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4, in T5 arg5)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
where T5 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
case 5: err = dest.Append(in arg5); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T5">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T6">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg5">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg6">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/), typeof(FixedString128Bytes /*T5*/), typeof(FixedString128Bytes /*T6*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4, T5, T6>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4, in T5 arg5, in T6 arg6)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
where T5 : unmanaged, INativeList<byte>, IUTF8Bytes
where T6 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
case 5: err = dest.Append(in arg5); break;
case 6: err = dest.Append(in arg6); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T5">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T6">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T7">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg5">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg6">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg7">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/), typeof(FixedString128Bytes /*T5*/), typeof(FixedString128Bytes /*T6*/), typeof(FixedString128Bytes /*T7*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4, T5, T6, T7>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4, in T5 arg5, in T6 arg6, in T7 arg7)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
where T5 : unmanaged, INativeList<byte>, IUTF8Bytes
where T6 : unmanaged, INativeList<byte>, IUTF8Bytes
where T7 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
case 5: err = dest.Append(in arg5); break;
case 6: err = dest.Append(in arg6); break;
case 7: err = dest.Append(in arg7); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T5">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T6">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T7">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T8">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg5">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg6">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg7">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg8">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/), typeof(FixedString128Bytes /*T5*/), typeof(FixedString128Bytes /*T6*/), typeof(FixedString128Bytes /*T7*/), typeof(FixedString128Bytes /*T8*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4, T5, T6, T7, T8>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4, in T5 arg5, in T6 arg6, in T7 arg7, in T8 arg8)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
where T5 : unmanaged, INativeList<byte>, IUTF8Bytes
where T6 : unmanaged, INativeList<byte>, IUTF8Bytes
where T7 : unmanaged, INativeList<byte>, IUTF8Bytes
where T8 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
case 5: err = dest.Append(in arg5); break;
case 6: err = dest.Append(in arg6); break;
case 7: err = dest.Append(in arg7); break;
case 8: err = dest.Append(in arg8); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
/// <summary>
/// Interpolates strings into a format string and appends the result to this string.
/// </summary>
/// <remarks>
/// Similar to `StringBuilder.AppendFormat` but with significant limitations:
/// - Only supports FixedString*N*Bytes arguments. To use other string types, convert them to FixedString*N*Bytes first.
/// - Only supports numeric format placeholders of the form `{0}` .. `{N}`.
/// - No format modifiers (*e.g.* `{0:x}`) are supported.
///
/// The overloads of this method take up to ten strings to interpolate into the format string.
/// </remarks>
/// <typeparam name="T">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="U">A FixedString*N*Bytes type.</typeparam>
/// <typeparam name="T0">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T1">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T2">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T3">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T4">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T5">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T6">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T7">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T8">The type of value to interpolate into the format string.</typeparam>
/// <typeparam name="T9">The type of value to interpolate into the format string.</typeparam>
/// <param name="dest">The string to append to.</param>d
/// <param name="format">A string to be interpolated and appended.</param>
/// <param name="arg0">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg1">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg2">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg3">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg4">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg5">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg6">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg7">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg8">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <param name="arg9">A FixedString*N*Bytes to interpolate into the format string.</param>
/// <returns><see cref="FormatError.None"/> if successful. Otherwise returns the appropriate <see cref="FormatError"/>.</returns>
[GenerateTestsForBurstCompatibility(GenericTypeArguments = new[] { typeof(FixedString128Bytes /*T*/), typeof(FixedString128Bytes /*U*/), typeof(FixedString128Bytes /*T0*/), typeof(FixedString128Bytes /*T1*/), typeof(FixedString128Bytes /*T2*/), typeof(FixedString128Bytes /*T3*/), typeof(FixedString128Bytes /*T4*/), typeof(FixedString128Bytes /*T5*/), typeof(FixedString128Bytes /*T6*/), typeof(FixedString128Bytes /*T7*/), typeof(FixedString128Bytes /*T8*/), typeof(FixedString128Bytes /*T9*/) })]
public static unsafe FormatError AppendFormat<T, U, T0, T1, T2, T3, T4, T5, T6, T7, T8, T9>(ref this T dest, in U format, in T0 arg0, in T1 arg1, in T2 arg2, in T3 arg3, in T4 arg4, in T5 arg5, in T6 arg6, in T7 arg7, in T8 arg8, in T9 arg9)
where T : unmanaged, INativeList<byte>, IUTF8Bytes
where U : unmanaged, INativeList<byte>, IUTF8Bytes
where T0 : unmanaged, INativeList<byte>, IUTF8Bytes
where T1 : unmanaged, INativeList<byte>, IUTF8Bytes
where T2 : unmanaged, INativeList<byte>, IUTF8Bytes
where T3 : unmanaged, INativeList<byte>, IUTF8Bytes
where T4 : unmanaged, INativeList<byte>, IUTF8Bytes
where T5 : unmanaged, INativeList<byte>, IUTF8Bytes
where T6 : unmanaged, INativeList<byte>, IUTF8Bytes
where T7 : unmanaged, INativeList<byte>, IUTF8Bytes
where T8 : unmanaged, INativeList<byte>, IUTF8Bytes
where T9 : unmanaged, INativeList<byte>, IUTF8Bytes
{
ref var formatRef = ref UnsafeUtilityExtensions.AsRef(in format);
int formatLength = formatRef.Length;
byte* formatBytes = formatRef.GetUnsafePtr();
int i = 0;
FormatError err = FormatError.None;
while (i < formatLength)
{
byte currByte = formatBytes[i++];
if (currByte == (byte)'{')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
return FormatError.BadFormatSpecifier;
if (currByte >= (byte)'0' && currByte <= (byte)'9' && i < formatLength && formatBytes[i++] == (byte)'}')
{
switch (currByte - (byte)'0')
{
case 0: err = dest.Append(in arg0); break;
case 1: err = dest.Append(in arg1); break;
case 2: err = dest.Append(in arg2); break;
case 3: err = dest.Append(in arg3); break;
case 4: err = dest.Append(in arg4); break;
case 5: err = dest.Append(in arg5); break;
case 6: err = dest.Append(in arg6); break;
case 7: err = dest.Append(in arg7); break;
case 8: err = dest.Append(in arg8); break;
case 9: err = dest.Append(in arg9); break;
default: err = FormatError.BadFormatSpecifier; break;
}
}
else if (currByte == (byte)'{')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else if (currByte == (byte)'}')
{
if (i < formatLength)
currByte = formatBytes[i++];
else
err = FormatError.BadFormatSpecifier;
if (currByte == (byte)'}')
err = dest.AppendRawByte(currByte);
else
err = FormatError.BadFormatSpecifier;
}
else
err = dest.AppendRawByte(currByte);
if (err != FormatError.None)
return err;
}
return FormatError.None;
}
}
}