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.

37 lines
1.5 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. using System;
  2. namespace IPA.Logging.Printers
  3. {
  4. /// <summary>
  5. /// Prints a pretty message to the console.
  6. /// </summary>
  7. public class ColoredConsolePrinter : LogPrinter
  8. {
  9. Logger.LogLevel filter = Logger.LogLevel.All;
  10. /// <summary>
  11. /// A filter for this specific printer.
  12. /// </summary>
  13. public override Logger.LogLevel Filter { get => filter; set => filter = value; }
  14. /// <summary>
  15. /// The color to print messages as.
  16. /// </summary>
  17. public ConsoleColor Color { get; set; } = Console.ForegroundColor;
  18. /// <summary>
  19. /// Prints an entry to the associated file.
  20. /// </summary>
  21. /// <param name="level">the <see cref="Logger.Level"/> of the message</param>
  22. /// <param name="time">the <see cref="DateTime"/> the message was recorded at</param>
  23. /// <param name="logName">the name of the log that sent the message</param>
  24. /// <param name="message">the message to print</param>
  25. public override void Print(Logger.Level level, DateTime time, string logName, string message)
  26. {
  27. if (((byte)level & (byte)StandardLogger.PrintFilter) == 0) return;
  28. Console.ForegroundColor = Color;
  29. foreach (var line in message.Split(new[] { "\n", Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries))
  30. Console.WriteLine(Logger.LogFormat, line, logName, time, level.ToString().ToUpper());
  31. Console.ResetColor();
  32. }
  33. }
  34. }