forked from Mirror/Ryujinx
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>
42 lines
1.1 KiB
C#
42 lines
1.1 KiB
C#
using System.Text;
|
|
|
|
namespace Ryujinx.Common.Logging
|
|
{
|
|
internal class DefaultLogFormatter : ILogFormatter
|
|
{
|
|
private static readonly ObjectPool<StringBuilder> StringBuilderPool = SharedPools.Default<StringBuilder>();
|
|
|
|
public string Format(LogEventArgs args)
|
|
{
|
|
StringBuilder sb = StringBuilderPool.Allocate();
|
|
|
|
try
|
|
{
|
|
sb.Clear();
|
|
|
|
sb.Append($@"{args.Time:hh\:mm\:ss\.fff}");
|
|
sb.Append($" |{args.Level.ToString()[0]}| ");
|
|
|
|
if (args.ThreadName != null)
|
|
{
|
|
sb.Append(args.ThreadName);
|
|
sb.Append(' ');
|
|
}
|
|
|
|
sb.Append(args.Message);
|
|
|
|
if (args.Data is not null)
|
|
{
|
|
sb.Append(' ');
|
|
DynamicObjectFormatter.Format(sb, args.Data);
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
finally
|
|
{
|
|
StringBuilderPool.Release(sb);
|
|
}
|
|
}
|
|
}
|
|
}
|