mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-22 19:03:29 +08:00
- 将 AbstractLogger 实现从 ILogger 扩展为 IStructuredLogger 接口 - 添加通用日志方法 Log(LogLevel, string, params object[]) 支持格式化参数 - 实现结构化日志方法支持属性键值对记录 - 添加 ConsoleAppender、FileAppender 和 AsyncLogAppender 日志输出器 - 实现 CompositeFilter 过滤器和 DefaultLogFormatter、JsonLogFormatter 格式化器 - 在 ConsoleLogger 和 GodotLogger 中使用预缓存的日志级别字符串提升性能 - 使用 ANSI 颜色代码替代 ConsoleColor 实现跨平台日志着色 - 在 ConsoleLoggerFactoryProvider 和 GodotLoggerFactoryProvider 中添加日志工厂缓存 - 优化 FileStorage 中目录遍历使用 OfType<string>() 类型转换 - 添加 LogContext 支持异步流中的结构化属性传递
34 lines
1.1 KiB
C#
34 lines
1.1 KiB
C#
using GFramework.Core.Abstractions.logging;
|
|
|
|
namespace GFramework.Core.logging;
|
|
|
|
/// <summary>
|
|
/// 控制台日志记录器工厂提供程序,用于创建控制台日志记录器实例
|
|
/// </summary>
|
|
public sealed class ConsoleLoggerFactoryProvider : ILoggerFactoryProvider
|
|
{
|
|
private readonly ILoggerFactory _cachedFactory;
|
|
|
|
/// <summary>
|
|
/// 初始化控制台日志记录器工厂提供程序
|
|
/// </summary>
|
|
public ConsoleLoggerFactoryProvider()
|
|
{
|
|
_cachedFactory = new CachedLoggerFactory(new ConsoleLoggerFactory());
|
|
}
|
|
|
|
/// <summary>
|
|
/// 获取或设置日志记录器的最小日志级别,低于此级别的日志将被忽略
|
|
/// </summary>
|
|
public LogLevel MinLevel { get; set; } = LogLevel.Info;
|
|
|
|
/// <summary>
|
|
/// 创建一个日志记录器实例(带缓存)
|
|
/// </summary>
|
|
/// <param name="name">日志记录器的名称,用于标识特定的日志源</param>
|
|
/// <returns>配置了指定名称和最小日志级别的ILogger实例</returns>
|
|
public ILogger CreateLogger(string name)
|
|
{
|
|
return _cachedFactory.GetLogger(name, MinLevel);
|
|
}
|
|
} |