Files
Fishing2Server/Fantasy/Fantays.Console/Runtime/Core/Log/Log.cs
2025-06-30 10:51:37 +08:00

189 lines
5.7 KiB
C#

using System;
using System.Diagnostics;
#if FANTASY_NET
using Fantasy.Platform.Net;
#endif
#pragma warning disable CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
namespace Fantasy
{
/// <summary>
/// 提供日志记录功能的静态类。
/// </summary>
public static class Log
{
private static ILog _logCore;
private static bool _isRegister;
#if FANTASY_NET
/// <summary>
/// 初始化Log系统
/// </summary>
public static void Initialize()
{
if (!_isRegister)
{
Register(new ConsoleLog());
return;
}
var processMode = ProcessMode.None;
switch (ProcessDefine.Options.Mode)
{
case "Develop":
{
processMode = ProcessMode.Develop;
break;
}
case "Release":
{
processMode = ProcessMode.Release;
break;
}
}
_logCore.Initialize(processMode);
}
#endif
/// <summary>
/// 注册一个日志系统
/// </summary>
/// <param name="log"></param>
public static void Register(ILog log)
{
if (_isRegister)
{
return;
}
_logCore = log;
_isRegister = true;
}
/// <summary>
/// 记录跟踪级别的日志消息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void Trace(string msg)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{msg}\n{st}");
}
/// <summary>
/// 记录调试级别的日志消息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void Debug(string msg)
{
_logCore.Debug(msg);
}
/// <summary>
/// 记录信息级别的日志消息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void Info(string msg)
{
_logCore.Info(msg);
}
/// <summary>
/// 记录跟踪级别的日志消息,并附带调用栈信息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void TraceInfo(string msg)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{msg}\n{st}");
}
/// <summary>
/// 记录警告级别的日志消息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void Warning(string msg)
{
_logCore.Warning(msg);
}
/// <summary>
/// 记录错误级别的日志消息,并附带调用栈信息。
/// </summary>
/// <param name="msg">日志消息。</param>
public static void Error(string msg)
{
var st = new StackTrace(1, true);
_logCore.Error($"{msg}\n{st}");
}
/// <summary>
/// 记录异常的错误级别的日志消息,并附带调用栈信息。
/// </summary>
/// <param name="e">异常对象。</param>
public static void Error(Exception e)
{
if (e.Data.Contains("StackTrace"))
{
_logCore.Error($"{e.Data["StackTrace"]}\n{e}");
return;
}
var str = e.ToString();
_logCore.Error(str);
}
/// <summary>
/// 记录跟踪级别的格式化日志消息,并附带调用栈信息。
/// </summary>
/// <param name="message">日志消息模板。</param>
/// <param name="args">格式化参数。</param>
public static void Trace(string message, params object[] args)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{string.Format(message, args)}\n{st}");
}
/// <summary>
/// 记录警告级别的格式化日志消息。
/// </summary>
/// <param name="message">日志消息模板。</param>
/// <param name="args">格式化参数。</param>
public static void Warning(string message, params object[] args)
{
_logCore.Warning(string.Format(message, args));
}
/// <summary>
/// 记录信息级别的格式化日志消息。
/// </summary>
/// <param name="message">日志消息模板。</param>
/// <param name="args">格式化参数。</param>
public static void Info(string message, params object[] args)
{
_logCore.Info(string.Format(message, args));
}
/// <summary>
/// 记录调试级别的格式化日志消息。
/// </summary>
/// <param name="message">日志消息模板。</param>
/// <param name="args">格式化参数。</param>
public static void Debug(string message, params object[] args)
{
_logCore.Debug(string.Format(message, args));
}
/// <summary>
/// 记录错误级别的格式化日志消息,并附带调用栈信息。
/// </summary>
/// <param name="message">日志消息模板。</param>
/// <param name="args">格式化参数。</param>
public static void Error(string message, params object[] args)
{
var st = new StackTrace(1, true);
var s = string.Format(message, args) + '\n' + st;
_logCore.Error(s);
}
}
}