| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- using System;
- using System.Collections.Concurrent;
- namespace Ryujinx.Common.Logging
- {
- public class ConsoleLogTarget : ILogTarget
- {
- private static readonly ConcurrentDictionary<LogLevel, ConsoleColor> _logColors;
- private readonly ILogFormatter _formatter;
- private readonly string _name;
- string ILogTarget.Name { get => _name; }
- static ConsoleLogTarget()
- {
- _logColors = new ConcurrentDictionary<LogLevel, ConsoleColor> {
- [ LogLevel.Stub ] = ConsoleColor.DarkGray,
- [ LogLevel.Info ] = ConsoleColor.White,
- [ LogLevel.Warning ] = ConsoleColor.Yellow,
- [ LogLevel.Error ] = ConsoleColor.Red
- };
- }
- public ConsoleLogTarget(string name)
- {
- _formatter = new DefaultLogFormatter();
- _name = name;
- }
- public void Log(object sender, LogEventArgs args)
- {
- if (_logColors.TryGetValue(args.Level, out ConsoleColor color))
- {
- Console.ForegroundColor = color;
- Console.WriteLine(_formatter.Format(args));
- Console.ResetColor();
- }
- else
- {
- Console.WriteLine(_formatter.Format(args));
- }
- }
- public void Dispose()
- {
- Console.ResetColor();
- }
- }
- }
|