v0.90.10
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
|
||||
@@ -7,21 +8,79 @@ namespace AssetStudio
|
||||
{
|
||||
public static class Logger
|
||||
{
|
||||
public static ILogger Default = new DummyLogger();
|
||||
public static bool Silent = false;
|
||||
private static bool _fileLogging = true;
|
||||
|
||||
public static void Verbose(string message) => Default.Log(LoggerEvent.Verbose, message, Silent);
|
||||
public static void Debug(string message) => Default.Log(LoggerEvent.Debug, message, Silent);
|
||||
public static void Info(string message) => Default.Log(LoggerEvent.Info, message, Silent);
|
||||
public static void Warning(string message) => Default.Log(LoggerEvent.Warning, message, Silent);
|
||||
public static void Error(string message) => Default.Log(LoggerEvent.Error, message, Silent);
|
||||
public static ILogger Default = new DummyLogger();
|
||||
public static ILogger File;
|
||||
public static bool Silent = false;
|
||||
public static bool LogVerbose = false;
|
||||
|
||||
public static bool FileLogging
|
||||
{
|
||||
get => _fileLogging;
|
||||
set
|
||||
{
|
||||
_fileLogging = value;
|
||||
if (_fileLogging)
|
||||
{
|
||||
File = new FileLogger();
|
||||
}
|
||||
else
|
||||
{
|
||||
((FileLogger)File)?.Writer?.Dispose();
|
||||
File = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static void Verbose(string message)
|
||||
{
|
||||
if (LogVerbose)
|
||||
{
|
||||
try
|
||||
{
|
||||
var callerMethod = new StackTrace().GetFrame(1).GetMethod();
|
||||
var callerMethodClass = callerMethod.ReflectedType.Name;
|
||||
if (!string.IsNullOrEmpty(callerMethodClass))
|
||||
{
|
||||
message = $"[{callerMethodClass}] {message}";
|
||||
}
|
||||
}
|
||||
catch (Exception) { }
|
||||
if (FileLogging) File.Log(LoggerEvent.Verbose, message);
|
||||
Default.Log(LoggerEvent.Verbose, message, Silent);
|
||||
}
|
||||
}
|
||||
public static void Debug(string message)
|
||||
{
|
||||
if (FileLogging) File.Log(LoggerEvent.Debug, message);
|
||||
Default.Log(LoggerEvent.Debug, message, Silent);
|
||||
}
|
||||
public static void Info(string message)
|
||||
{
|
||||
if (FileLogging) File.Log(LoggerEvent.Info, message);
|
||||
Default.Log(LoggerEvent.Info, message, Silent);
|
||||
}
|
||||
public static void Warning(string message)
|
||||
{
|
||||
if (FileLogging) File.Log(LoggerEvent.Warning, message);
|
||||
Default.Log(LoggerEvent.Warning, message, Silent);
|
||||
}
|
||||
public static void Error(string message)
|
||||
{
|
||||
if (FileLogging) File.Log(LoggerEvent.Error, message);
|
||||
Default.Log(LoggerEvent.Error, message, Silent);
|
||||
}
|
||||
|
||||
public static void Error(string message, Exception e)
|
||||
{
|
||||
var sb = new StringBuilder();
|
||||
sb.AppendLine(message);
|
||||
sb.AppendLine(e.ToString());
|
||||
Default.Log(LoggerEvent.Error, sb.ToString(), Silent);
|
||||
|
||||
message = sb.ToString();
|
||||
if (FileLogging) File.Log(LoggerEvent.Error, message);
|
||||
Default.Log(LoggerEvent.Error, message, Silent);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user