forked from Mirror/Ryujinx
ac21abbb9d
* Preparation for initial Flatpack and FlatHub integration This integrate some initial changes required for Flatpack and distribution from FlatHub. Also added some resources that will be used for packaging on Linux. * Address gdkchan comment
94 lines
3.4 KiB
C#
94 lines
3.4 KiB
C#
using Ryujinx.Common;
|
|
using Ryujinx.Common.Logging;
|
|
using System;
|
|
|
|
namespace Ryujinx.Configuration
|
|
{
|
|
public static class LoggerModule
|
|
{
|
|
public static void Initialize()
|
|
{
|
|
ConfigurationState.Instance.Logger.EnableDebug.Event += ReloadEnableDebug;
|
|
ConfigurationState.Instance.Logger.EnableStub.Event += ReloadEnableStub;
|
|
ConfigurationState.Instance.Logger.EnableInfo.Event += ReloadEnableInfo;
|
|
ConfigurationState.Instance.Logger.EnableWarn.Event += ReloadEnableWarning;
|
|
ConfigurationState.Instance.Logger.EnableError.Event += ReloadEnableError;
|
|
ConfigurationState.Instance.Logger.EnableTrace.Event += ReloadEnableTrace;
|
|
ConfigurationState.Instance.Logger.EnableGuest.Event += ReloadEnableGuest;
|
|
ConfigurationState.Instance.Logger.EnableFsAccessLog.Event += ReloadEnableFsAccessLog;
|
|
ConfigurationState.Instance.Logger.FilteredClasses.Event += ReloadFilteredClasses;
|
|
ConfigurationState.Instance.Logger.EnableFileLog.Event += ReloadFileLogger;
|
|
}
|
|
|
|
private static void ReloadEnableDebug(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Debug, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableStub(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Stub, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableInfo(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Info, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableWarning(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Warning, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableError(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Error, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableTrace(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Trace, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableGuest(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.Guest, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadEnableFsAccessLog(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
Logger.SetEnable(LogLevel.AccessLog, e.NewValue);
|
|
}
|
|
|
|
private static void ReloadFilteredClasses(object sender, ReactiveEventArgs<LogClass[]> e)
|
|
{
|
|
bool noFilter = e.NewValue.Length == 0;
|
|
|
|
foreach (var logClass in Enum.GetValues<LogClass>())
|
|
{
|
|
Logger.SetEnable(logClass, noFilter);
|
|
}
|
|
|
|
foreach (var logClass in e.NewValue)
|
|
{
|
|
Logger.SetEnable(logClass, true);
|
|
}
|
|
}
|
|
|
|
private static void ReloadFileLogger(object sender, ReactiveEventArgs<bool> e)
|
|
{
|
|
if (e.NewValue)
|
|
{
|
|
Logger.AddTarget(new AsyncLogTargetWrapper(
|
|
new FileLogTarget(ReleaseInformations.GetBaseApplicationDirectory(), "file"),
|
|
1000,
|
|
AsyncLogTargetOverflowAction.Block
|
|
));
|
|
}
|
|
else
|
|
{
|
|
Logger.RemoveTarget("file");
|
|
}
|
|
}
|
|
}
|
|
}
|