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>
30 lines
900 B
C#
30 lines
900 B
C#
using System;
|
|
using System.Text.Json.Serialization;
|
|
|
|
namespace Ryujinx.Common.Logging
|
|
{
|
|
internal class LogEventArgsJson
|
|
{
|
|
public LogLevel Level { get; }
|
|
public TimeSpan Time { get; }
|
|
public string ThreadName { get; }
|
|
|
|
public string Message { get; }
|
|
public string Data { get; }
|
|
|
|
[JsonConstructor]
|
|
public LogEventArgsJson(LogLevel level, TimeSpan time, string threadName, string message, string data = null)
|
|
{
|
|
Level = level;
|
|
Time = time;
|
|
ThreadName = threadName;
|
|
Message = message;
|
|
Data = data;
|
|
}
|
|
|
|
public static LogEventArgsJson FromLogEventArgs(LogEventArgs args)
|
|
{
|
|
return new LogEventArgsJson(args.Level, args.Time, args.ThreadName, args.Message, DynamicObjectFormatter.Format(args.Data));
|
|
}
|
|
}
|
|
} |