using System;
using System.Reflection;
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.AppendFormat(@"{0:hh\:mm\:ss\.fff}", args.Time);
sb.Append($" |{args.Level.ToString()[0]}| ");
if (args.ThreadName != null)
sb.Append(args.ThreadName);
sb.Append(' ');
}
sb.Append(args.Message);
if (args.Data != null)
PropertyInfo[] props = args.Data.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(args.Data);
foreach (var item in array)
sb.Append(item.ToString());
sb.Append(", ");
if (array.Length > 0)
sb.Remove(sb.Length - 2, 2);
else
sb.Append(prop.GetValue(args.Data));
sb.Append(" ; ");
// We remove the final ';' from the string
if (props.Length > 0)
sb.Remove(sb.Length - 3, 3);
sb.Append('}');
return sb.ToString();
finally
_stringBuilderPool.Release(sb);