PowerToys/Wox.Infrastructure/Logger/Log.cs

100 lines
3.0 KiB
C#
Raw Normal View History

using System.Diagnostics;
using System.IO;
using NLog;
using NLog.Config;
using NLog.Targets;
2013-12-20 19:38:10 +08:00
2014-09-19 16:57:48 +08:00
namespace Wox.Infrastructure.Logger
2013-12-20 19:38:10 +08:00
{
public static class Log
2013-12-20 19:38:10 +08:00
{
public const string DirectoryName = "Logs";
static Log()
{
var path = Path.Combine(Constant.DataDirectory, DirectoryName, Constant.Version);
if (!Directory.Exists(path))
{
Directory.CreateDirectory(path);
}
2013-12-20 19:38:10 +08:00
var configuration = new LoggingConfiguration();
var target = new FileTarget();
configuration.AddTarget("file", target);
2016-05-24 04:34:19 +08:00
target.FileName = "${specialfolder:folder=ApplicationData}/" + Constant.Wox + "/" + DirectoryName + "/" + Constant.Version + "/${shortdate}.txt";
var rule = new LoggingRule("*", LogLevel.Info, target);
configuration.LoggingRules.Add(rule);
LogManager.Configuration = configuration;
}
private static string CallerType()
{
var stackTrace = new StackTrace();
2016-05-08 02:16:13 +08:00
var stackFrames = stackTrace.GetFrames().NonNull();
var callingFrame = stackFrames[2];
var method = callingFrame.GetMethod();
2016-05-08 02:16:13 +08:00
var type = $"{method.DeclaringType.NonNull().FullName}.{method.Name}";
return type;
}
2016-05-16 00:03:06 +08:00
public static void Error(string msg)
2015-01-11 21:52:30 +08:00
{
var type = CallerType();
var logger = LogManager.GetLogger(type);
2016-05-16 00:03:06 +08:00
System.Diagnostics.Debug.WriteLine($"ERROR: {msg}");
logger.Error(msg);
}
public static void Exception(System.Exception e)
{
#if DEBUG
throw e;
#else
2016-05-16 00:03:06 +08:00
var type = CallerType();
var logger = LogManager.GetLogger(type);
do
2015-11-11 08:42:49 +08:00
{
logger.Error(e.Message);
2016-05-16 00:03:06 +08:00
logger.Error($"\n{e.StackTrace}");
2015-11-11 08:42:49 +08:00
e = e.InnerException;
2016-05-16 00:03:06 +08:00
} while (e != null);
#endif
2015-01-11 21:52:30 +08:00
}
2014-03-23 17:43:46 +08:00
public static void Debug(string msg)
{
var type = CallerType();
var logger = LogManager.GetLogger(type);
System.Diagnostics.Debug.WriteLine($"DEBUG: {msg}");
2015-01-20 22:33:45 +08:00
logger.Debug(msg);
2014-03-23 17:43:46 +08:00
}
public static void Info(string msg)
{
var type = CallerType();
var logger = LogManager.GetLogger(type);
System.Diagnostics.Debug.WriteLine($"INFO: {msg}");
2015-01-20 22:33:45 +08:00
logger.Info(msg);
2014-03-23 17:43:46 +08:00
}
public static void Warn(string msg)
{
var type = CallerType();
var logger = LogManager.GetLogger(type);
System.Diagnostics.Debug.WriteLine($"WARN: {msg}");
2015-01-20 22:33:45 +08:00
logger.Warn(msg);
2014-03-23 17:43:46 +08:00
}
2015-11-09 09:32:33 +08:00
public static void Fatal(System.Exception e)
2014-03-23 17:43:46 +08:00
{
#if DEBUG
throw e;
#else
2016-05-18 05:48:18 +08:00
var type = CallerType();
var logger = LogManager.GetLogger(type);
logger.Fatal(ExceptionFormatter.FormatExcpetion(e));
#endif
2014-03-23 17:43:46 +08:00
}
2013-12-20 19:38:10 +08:00
}
}