mirror of
https://github.com/cemu-project/DS4Windows.git
synced 2024-11-27 03:24:20 +01:00
45 lines
1.4 KiB
C#
45 lines
1.4 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using NLog;
|
|
using NLog.Targets.Wrappers;
|
|
|
|
namespace DS4WinWPF
|
|
{
|
|
public class LoggerHolder
|
|
{
|
|
private Logger logger;// = LogManager.GetCurrentClassLogger();
|
|
public Logger Logger { get => logger; }
|
|
|
|
public LoggerHolder(DS4Windows.ControlService service)
|
|
{
|
|
var configuration = LogManager.Configuration;
|
|
var wrapTarget = configuration.FindTargetByName<WrapperTargetBase>("logfile") as WrapperTargetBase;
|
|
var fileTarget = wrapTarget.WrappedTarget as NLog.Targets.FileTarget;
|
|
fileTarget.FileName = $@"{DS4Windows.Global.appdatapath}\Logs\ds4windows_log.txt";
|
|
fileTarget.ArchiveFileName = $@"{DS4Windows.Global.appdatapath}\Logs\ds4windows_log_{{#}}.txt";
|
|
LogManager.Configuration = configuration;
|
|
LogManager.ReconfigExistingLoggers();
|
|
|
|
logger = LogManager.GetCurrentClassLogger();
|
|
|
|
service.Debug += WriteToLog;
|
|
DS4Windows.AppLogger.GuiLog += WriteToLog;
|
|
}
|
|
|
|
private void WriteToLog(object sender, DS4Windows.DebugEventArgs e)
|
|
{
|
|
if (!e.Warning)
|
|
{
|
|
logger.Info(e.Data);
|
|
}
|
|
else
|
|
{
|
|
logger.Warn(e.Data);
|
|
}
|
|
}
|
|
}
|
|
}
|