LogWindow.xaml.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. using MediaBrowser.Common.Implementations.Logging;
  2. using MediaBrowser.Model.Logging;
  3. using NLog;
  4. using NLog.Config;
  5. using NLog.Targets;
  6. using System.ComponentModel;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. using System.Windows;
  10. namespace MediaBrowser.ServerApplication.Logging
  11. {
  12. /// <summary>
  13. /// Interaction logic for LogWindow.xaml
  14. /// </summary>
  15. public partial class LogWindow : Window
  16. {
  17. /// <summary>
  18. /// The _ui thread
  19. /// </summary>
  20. private readonly TaskScheduler _uiThread;
  21. private readonly ILogManager _logManager;
  22. /// <summary>
  23. /// Initializes a new instance of the <see cref="LogWindow" /> class.
  24. /// </summary>
  25. /// <param name="kernel">The kernel.</param>
  26. public LogWindow(ILogManager logManager)
  27. {
  28. InitializeComponent();
  29. _uiThread = TaskScheduler.FromCurrentSynchronizationContext();
  30. _logManager = logManager;
  31. Loaded += LogWindow_Loaded;
  32. }
  33. /// <summary>
  34. /// Handles the Loaded event of the LogWindow control.
  35. /// </summary>
  36. /// <param name="sender">The source of the event.</param>
  37. /// <param name="e">The <see cref="RoutedEventArgs" /> instance containing the event data.</param>
  38. void LogWindow_Loaded(object sender, RoutedEventArgs e)
  39. {
  40. var target = new TraceTarget
  41. {
  42. Layout = "${longdate}, ${level}, ${logger}, ${message}"
  43. };
  44. ((NlogManager)_logManager).RemoveTarget("LogWindowTraceTarget");
  45. AddLogTarget(target, "LogWindowTraceTarget");
  46. }
  47. /// <summary>
  48. /// Raises the <see cref="E:System.Windows.Window.Closing" /> event.
  49. /// </summary>
  50. /// <param name="e">A <see cref="T:System.ComponentModel.CancelEventArgs" /> that contains the event data.</param>
  51. protected override void OnClosing(CancelEventArgs e)
  52. {
  53. base.OnClosing(e);
  54. ((NlogManager) _logManager).RemoveTarget("LogWindowTraceTarget");
  55. }
  56. /// <summary>
  57. /// Logs the message.
  58. /// </summary>
  59. /// <param name="msg">The MSG.</param>
  60. public async void LogMessage(string msg)
  61. {
  62. await Task.Factory.StartNew(() => lbxLogData.Items.Insert(0, msg.TrimEnd('\n')), CancellationToken.None, TaskCreationOptions.None, _uiThread);
  63. }
  64. /// <summary>
  65. /// The log layout
  66. /// </summary>
  67. /// <value>The log layout.</value>
  68. public string LogLayout
  69. {
  70. get { return "${longdate}, ${level}, ${logger}, ${message}"; }
  71. }
  72. /// <summary>
  73. /// Adds the log target.
  74. /// </summary>
  75. /// <param name="target">The target.</param>
  76. /// <param name="name">The name.</param>
  77. private void AddLogTarget(Target target, string name)
  78. {
  79. var config = NLog.LogManager.Configuration;
  80. target.Name = name;
  81. config.AddTarget(name, target);
  82. var level = LogLevel.Debug;
  83. var rule = new LoggingRule("*", level, target);
  84. config.LoggingRules.Add(rule);
  85. NLog.LogManager.Configuration = config;
  86. }
  87. /// <summary>
  88. /// Shuts down.
  89. /// </summary>
  90. public async void ShutDown()
  91. {
  92. await Task.Factory.StartNew(Close, CancellationToken.None, TaskCreationOptions.None, _uiThread);
  93. }
  94. }
  95. }