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
{
///
/// 提供日志记录功能的静态类。
///
public static class Log
{
private static ILog _logCore;
private static bool _isRegister;
#if FANTASY_NET
///
/// 初始化Log系统
///
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
///
/// 注册一个日志系统
///
///
public static void Register(ILog log)
{
if (_isRegister)
{
return;
}
_logCore = log;
_isRegister = true;
}
///
/// 记录跟踪级别的日志消息。
///
/// 日志消息。
public static void Trace(string msg)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{msg}\n{st}");
}
///
/// 记录调试级别的日志消息。
///
/// 日志消息。
public static void Debug(string msg)
{
_logCore.Debug(msg);
}
///
/// 记录信息级别的日志消息。
///
/// 日志消息。
public static void Info(string msg)
{
_logCore.Info(msg);
}
///
/// 记录跟踪级别的日志消息,并附带调用栈信息。
///
/// 日志消息。
public static void TraceInfo(string msg)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{msg}\n{st}");
}
///
/// 记录警告级别的日志消息。
///
/// 日志消息。
public static void Warning(string msg)
{
_logCore.Warning(msg);
}
///
/// 记录错误级别的日志消息,并附带调用栈信息。
///
/// 日志消息。
public static void Error(string msg)
{
var st = new StackTrace(1, true);
_logCore.Error($"{msg}\n{st}");
}
///
/// 记录异常的错误级别的日志消息,并附带调用栈信息。
///
/// 异常对象。
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);
}
///
/// 记录跟踪级别的格式化日志消息,并附带调用栈信息。
///
/// 日志消息模板。
/// 格式化参数。
public static void Trace(string message, params object[] args)
{
var st = new StackTrace(1, true);
_logCore.Trace($"{string.Format(message, args)}\n{st}");
}
///
/// 记录警告级别的格式化日志消息。
///
/// 日志消息模板。
/// 格式化参数。
public static void Warning(string message, params object[] args)
{
_logCore.Warning(string.Format(message, args));
}
///
/// 记录信息级别的格式化日志消息。
///
/// 日志消息模板。
/// 格式化参数。
public static void Info(string message, params object[] args)
{
_logCore.Info(string.Format(message, args));
}
///
/// 记录调试级别的格式化日志消息。
///
/// 日志消息模板。
/// 格式化参数。
public static void Debug(string message, params object[] args)
{
_logCore.Debug(string.Format(message, args));
}
///
/// 记录错误级别的格式化日志消息,并附带调用栈信息。
///
/// 日志消息模板。
/// 格式化参数。
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);
}
}
}