You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

29 lines
1.1 KiB

  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using IllusionPlugin.Logging;
  8. using LoggerBase = IllusionPlugin.Logging.Logger;
  9. namespace IllusionInjector.Logging.Printers
  10. {
  11. public class ColoredConsolePrinter : LogPrinter
  12. {
  13. LoggerBase.LogLevel filter = LoggerBase.LogLevel.All;
  14. public override LoggerBase.LogLevel Filter { get => filter; set => filter = value; }
  15. ConsoleColor color = Console.ForegroundColor;
  16. public ConsoleColor Color { get => color; set => color = value; }
  17. public override void Print(LoggerBase.Level level, DateTime time, string logName, string message)
  18. {
  19. if (((byte)level & (byte)Filter) == 0) return;
  20. Console.ForegroundColor = color;
  21. foreach (var line in message.Split(new string[] { "\n", Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries))
  22. Console.WriteLine(string.Format(LoggerBase.LogFormat, line, logName, time, level.ToString().ToUpper()));
  23. Console.ResetColor();
  24. }
  25. }
  26. }