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>
40 lines
996 B
C#
40 lines
996 B
C#
using Ryujinx.Common.Utilities;
|
|
using System.IO;
|
|
|
|
namespace Ryujinx.Common.Logging
|
|
{
|
|
public class JsonLogTarget : ILogTarget
|
|
{
|
|
private Stream _stream;
|
|
private bool _leaveOpen;
|
|
private string _name;
|
|
|
|
string ILogTarget.Name { get => _name; }
|
|
|
|
public JsonLogTarget(Stream stream, string name)
|
|
{
|
|
_stream = stream;
|
|
_name = name;
|
|
}
|
|
|
|
public JsonLogTarget(Stream stream, bool leaveOpen)
|
|
{
|
|
_stream = stream;
|
|
_leaveOpen = leaveOpen;
|
|
}
|
|
|
|
public void Log(object sender, LogEventArgs e)
|
|
{
|
|
var logEventArgsJson = LogEventArgsJson.FromLogEventArgs(e);
|
|
JsonHelper.SerializeToStream(_stream, logEventArgsJson, LogEventJsonSerializerContext.Default.LogEventArgsJson);
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
if (!_leaveOpen)
|
|
{
|
|
_stream.Dispose();
|
|
}
|
|
}
|
|
}
|
|
}
|