mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-23 03:04:29 +08:00
- 将所有小写的命名空间导入更正为首字母大写格式 - 统一 GFramework 框架的命名空间引用规范 - 修复 core、ecs、godot 等模块的命名空间导入错误 - 标准化文档示例代码中的 using 语句格式 - 确保所有文档中的命名空间引用保持一致性 - 更新 global using 语句以匹配正确的命名空间格式
134 lines
3.7 KiB
C#
134 lines
3.7 KiB
C#
using GFramework.Core.Abstractions.Logging;
|
|
|
|
namespace GFramework.Core.Logging;
|
|
|
|
/// <summary>
|
|
/// 组合日志记录器,支持同时输出到多个 Appender
|
|
/// </summary>
|
|
public sealed class CompositeLogger : AbstractLogger, IDisposable
|
|
{
|
|
private readonly ILogAppender[] _appenders;
|
|
|
|
/// <summary>
|
|
/// 创建组合日志记录器
|
|
/// </summary>
|
|
/// <param name="name">日志记录器名称</param>
|
|
/// <param name="minLevel">最小日志级别</param>
|
|
/// <param name="appenders">日志输出器列表</param>
|
|
public CompositeLogger(
|
|
string name,
|
|
LogLevel minLevel,
|
|
params ILogAppender[] appenders)
|
|
: base(name, minLevel)
|
|
{
|
|
if (appenders == null || appenders.Length == 0)
|
|
throw new ArgumentException("At least one appender must be provided.", nameof(appenders));
|
|
|
|
_appenders = appenders;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 释放所有 Appender 资源
|
|
/// </summary>
|
|
public void Dispose()
|
|
{
|
|
foreach (var appender in _appenders)
|
|
{
|
|
if (appender is IDisposable disposable)
|
|
{
|
|
disposable.Dispose();
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 写入日志到所有 Appender
|
|
/// </summary>
|
|
/// <param name="level">日志级别</param>
|
|
/// <param name="message">日志消息</param>
|
|
/// <param name="exception">异常对象</param>
|
|
protected override void Write(LogLevel level, string message, Exception? exception)
|
|
{
|
|
var entry = new LogEntry(
|
|
DateTime.UtcNow,
|
|
level,
|
|
Name(),
|
|
message,
|
|
exception,
|
|
null);
|
|
|
|
foreach (var appender in _appenders)
|
|
{
|
|
appender.Append(entry);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 使用指定的日志级别记录消息和结构化属性
|
|
/// </summary>
|
|
/// <param name="level">日志级别</param>
|
|
/// <param name="message">日志消息</param>
|
|
/// <param name="properties">结构化属性键值对</param>
|
|
public override void Log(LogLevel level, string message, params (string Key, object? Value)[] properties)
|
|
{
|
|
if (!IsEnabled(level)) return;
|
|
|
|
var propsDict = properties.Length > 0
|
|
? properties.ToDictionary(p => p.Key, p => p.Value)
|
|
: null;
|
|
|
|
var entry = new LogEntry(
|
|
DateTime.UtcNow,
|
|
level,
|
|
Name(),
|
|
message,
|
|
null,
|
|
propsDict);
|
|
|
|
foreach (var appender in _appenders)
|
|
{
|
|
appender.Append(entry);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 使用指定的日志级别记录消息、异常和结构化属性
|
|
/// </summary>
|
|
/// <param name="level">日志级别</param>
|
|
/// <param name="message">日志消息</param>
|
|
/// <param name="exception">异常对象</param>
|
|
/// <param name="properties">结构化属性键值对</param>
|
|
public override void Log(LogLevel level, string message, Exception? exception,
|
|
params (string Key, object? Value)[] properties)
|
|
{
|
|
if (!IsEnabled(level)) return;
|
|
|
|
var propsDict = properties.Length > 0
|
|
? properties.ToDictionary(p => p.Key, p => p.Value)
|
|
: null;
|
|
|
|
var entry = new LogEntry(
|
|
DateTime.UtcNow,
|
|
level,
|
|
Name(),
|
|
message,
|
|
exception,
|
|
propsDict);
|
|
|
|
foreach (var appender in _appenders)
|
|
{
|
|
appender.Append(entry);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 刷新所有 Appender 的缓冲区
|
|
/// </summary>
|
|
public void Flush()
|
|
{
|
|
foreach (var appender in _appenders)
|
|
{
|
|
appender.Flush();
|
|
}
|
|
}
|
|
} |