mirror of
https://github.com/SabreTools/SabreTools.Serialization.git
synced 2026-02-14 05:36:30 +00:00
459 lines
17 KiB
C#
459 lines
17 KiB
C#
using System;
|
|
using System.Text;
|
|
using SabreTools.Numerics;
|
|
|
|
namespace SabreTools.Data.Extensions
|
|
{
|
|
// TODO: Add extension for printing enums, if possible
|
|
internal static class StringBuilderExtensions
|
|
{
|
|
/// <summary>
|
|
/// Append a line containing a boolean to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, bool? value, string prefixString)
|
|
{
|
|
value ??= false;
|
|
return sb.AppendLine($"{prefixString}: {value}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Char to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, char? value, string prefixString)
|
|
{
|
|
string valueString = (value == null ? "[NULL]" : value.Value.ToString());
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int8 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, sbyte? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X2})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian Int8 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothInt8? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt8 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, byte? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X2})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian UInt8 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothUInt8? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int16 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, short? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X4})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian Int16 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothInt16? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt16 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, ushort? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X4})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian UInt16 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothUInt16? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int32 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, int? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X8})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian Int32 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothInt32? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt32 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, uint? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X8})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian UInt32 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothUInt32? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Single to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, float? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value}";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int64 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, long? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X16})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian Int64 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothInt64? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt64 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, ulong? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value} (0x{value:X16})";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a potentially both-endian UInt64 to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLineBothEndian(this StringBuilder sb, BothUInt64? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
if (value.IsValid)
|
|
return sb.AppendLine(value, prefixString);
|
|
|
|
sb = sb.AppendLine(value.LittleEndian, $"{prefixString} (Little-Endian)");
|
|
return sb.AppendLine(value.BigEndian, $"{prefixString} (Big-Endian)");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Double to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, double? value, string prefixString)
|
|
{
|
|
value ??= 0;
|
|
string valueString = $"{value}";
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a string to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, string? value, string prefixString)
|
|
{
|
|
string valueString = value ?? "[NULL]";
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Guid to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, Guid? value, string prefixString)
|
|
{
|
|
value ??= Guid.Empty;
|
|
string valueString = value.Value.ToString();
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt8[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, byte[]? value, string prefixString)
|
|
{
|
|
string valueString = (value == null ? "[NULL]" : BitConverter.ToString(value).Replace('-', ' '));
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt8[] value as a string to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, byte[]? value, string prefixString, Encoding encoding)
|
|
{
|
|
string valueString = (value == null ? "[NULL]" : encoding.GetString(value).Replace("\0", string.Empty));
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Char[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, char[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, c => c.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int16[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, short[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, s => s.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt16[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, ushort[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, u => u.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int32[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, int[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, i => i.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt32[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, uint[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, u => u.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Single[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, float[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, u => u.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Int64[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, long[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, l => l.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt64[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, ulong[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, u => u.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a Double[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, double[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, u => u.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Append a line containing a UInt64[] value to a StringBuilder
|
|
/// </summary>
|
|
public static StringBuilder AppendLine(this StringBuilder sb, Guid[]? value, string prefixString)
|
|
{
|
|
string valueString = "[NULL]";
|
|
if (value != null)
|
|
{
|
|
var valueArr = Array.ConvertAll(value, g => g.ToString());
|
|
valueString = string.Join(", ", valueArr);
|
|
}
|
|
|
|
if (valueString.Length == 0)
|
|
return sb.AppendLine($"{prefixString}: [EMPTY]");
|
|
|
|
return sb.AppendLine($"{prefixString}: {valueString}");
|
|
}
|
|
}
|
|
}
|