4ce4299ca2
* Use source generated json serializers in order to improve code trimming * Use strongly typed github releases model to fetch updates instead of raw Newtonsoft.Json parsing * Use separate model for LogEventArgs serialization * Make dynamic object formatter static. Fix string builder pooling. * Do not inherit json version of LogEventArgs from EventArgs * Fix extra space in object formatting * Write log json directly to stream instead of using buffer writer * Rebase fixes * Rebase fixes * Rebase fixes * Enforce block-scoped namespaces in the solution. Convert style for existing code * Apply suggestions from code review Co-authored-by: TSRBerry <20988865+TSRBerry@users.noreply.github.com> * Rebase indent fix * Fix indent * Delete unnecessary json properties * Rebase fix * Remove overridden json property names as they are handled in the options * Apply suggestions from code review Co-authored-by: TSRBerry <20988865+TSRBerry@users.noreply.github.com> * Use default json options in github api calls * Indentation and spacing fixes --------- Co-authored-by: TSRBerry <20988865+TSRBerry@users.noreply.github.com>
84 lines
2.1 KiB
C#
84 lines
2.1 KiB
C#
#nullable enable
|
|
using System;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
|
|
namespace Ryujinx.Common.Logging
|
|
{
|
|
internal class DynamicObjectFormatter
|
|
{
|
|
private static readonly ObjectPool<StringBuilder> StringBuilderPool = SharedPools.Default<StringBuilder>();
|
|
|
|
public static string? Format(object? dynamicObject)
|
|
{
|
|
if (dynamicObject is null)
|
|
{
|
|
return null;
|
|
}
|
|
|
|
StringBuilder sb = StringBuilderPool.Allocate();
|
|
|
|
try
|
|
{
|
|
Format(sb, dynamicObject);
|
|
|
|
return sb.ToString();
|
|
}
|
|
finally
|
|
{
|
|
StringBuilderPool.Release(sb);
|
|
}
|
|
}
|
|
|
|
public static void Format(StringBuilder sb, object? dynamicObject)
|
|
{
|
|
if (dynamicObject is null)
|
|
{
|
|
return;
|
|
}
|
|
|
|
PropertyInfo[] props = dynamicObject.GetType().GetProperties();
|
|
|
|
sb.Append('{');
|
|
|
|
foreach (var prop in props)
|
|
{
|
|
sb.Append(prop.Name);
|
|
sb.Append(": ");
|
|
|
|
if (typeof(Array).IsAssignableFrom(prop.PropertyType))
|
|
{
|
|
Array? array = (Array?) prop.GetValue(dynamicObject);
|
|
|
|
if (array is not null)
|
|
{
|
|
foreach (var item in array)
|
|
{
|
|
sb.Append(item);
|
|
sb.Append(", ");
|
|
}
|
|
|
|
if (array.Length > 0)
|
|
{
|
|
sb.Remove(sb.Length - 2, 2);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
sb.Append(prop.GetValue(dynamicObject));
|
|
}
|
|
|
|
sb.Append(" ; ");
|
|
}
|
|
|
|
// We remove the final ';' from the string
|
|
if (props.Length > 0)
|
|
{
|
|
sb.Remove(sb.Length - 3, 3);
|
|
}
|
|
|
|
sb.Append('}');
|
|
}
|
|
}
|
|
} |