| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- 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);
- }
- }
- }
- }
|