aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common/Logging/LogWindow.xaml.cs
diff options
context:
space:
mode:
authorLukePulverenti <luke.pulverenti@gmail.com>2013-02-20 20:33:05 -0500
committerLukePulverenti <luke.pulverenti@gmail.com>2013-02-20 20:33:05 -0500
commit767cdc1f6f6a63ce997fc9476911e2c361f9d402 (patch)
tree49add55976f895441167c66cfa95e5c7688d18ce /MediaBrowser.Common/Logging/LogWindow.xaml.cs
parent845554722efaed872948a9e0f7202e3ef52f1b6e (diff)
Pushing missing changes
Diffstat (limited to 'MediaBrowser.Common/Logging/LogWindow.xaml.cs')
-rw-r--r--MediaBrowser.Common/Logging/LogWindow.xaml.cs128
1 files changed, 128 insertions, 0 deletions
diff --git a/MediaBrowser.Common/Logging/LogWindow.xaml.cs b/MediaBrowser.Common/Logging/LogWindow.xaml.cs
new file mode 100644
index 000000000..3dc11db5b
--- /dev/null
+++ b/MediaBrowser.Common/Logging/LogWindow.xaml.cs
@@ -0,0 +1,128 @@
+using MediaBrowser.Common.Kernel;
+using NLog;
+using NLog.Config;
+using NLog.Targets;
+using System.ComponentModel;
+using System.Threading;
+using System.Threading.Tasks;
+using System.Windows;
+
+namespace MediaBrowser.Common.Logging
+{
+ /// <summary>
+ /// Interaction logic for LogWindow.xaml
+ /// </summary>
+ public partial class LogWindow : Window
+ {
+ /// <summary>
+ /// The _ui thread
+ /// </summary>
+ private readonly TaskScheduler _uiThread;
+ /// <summary>
+ /// The _kernel
+ /// </summary>
+ private readonly IKernel _kernel;
+
+ /// <summary>
+ /// Initializes a new instance of the <see cref="LogWindow" /> class.
+ /// </summary>
+ /// <param name="kernel">The kernel.</param>
+ public LogWindow(IKernel kernel)
+ {
+ InitializeComponent();
+ _uiThread = TaskScheduler.FromCurrentSynchronizationContext();
+ _kernel = kernel;
+
+ Loaded += LogWindow_Loaded;
+ }
+
+ /// <summary>
+ /// Handles the Loaded event of the LogWindow control.
+ /// </summary>
+ /// <param name="sender">The source of the event.</param>
+ /// <param name="e">The <see cref="RoutedEventArgs" /> instance containing the event data.</param>
+ void LogWindow_Loaded(object sender, RoutedEventArgs e)
+ {
+ var target = new TraceTarget
+ {
+ Layout = "${longdate}, ${level}, ${logger}, ${message}"
+ };
+
+ AddLogTarget(target, "LogWindowTraceTarget");
+ }
+
+ /// <summary>
+ /// Raises the <see cref="E:System.Windows.Window.Closing" /> event.
+ /// </summary>
+ /// <param name="e">A <see cref="T:System.ComponentModel.CancelEventArgs" /> that contains the event data.</param>
+ protected override void OnClosing(CancelEventArgs e)
+ {
+ base.OnClosing(e);
+
+ RemoveLogTarget("LogWindowTraceTarget");
+ }
+
+ /// <summary>
+ /// Logs the message.
+ /// </summary>
+ /// <param name="msg">The MSG.</param>
+ public async void LogMessage(string msg)
+ {
+ await Task.Factory.StartNew(() => lbxLogData.Items.Insert(0, msg.TrimEnd('\n')), CancellationToken.None, TaskCreationOptions.None, _uiThread);
+ }
+
+ /// <summary>
+ /// The log layout
+ /// </summary>
+ /// <value>The log layout.</value>
+ public string LogLayout
+ {
+ get { return "${longdate}, ${level}, ${logger}, ${message}"; }
+ }
+
+ /// <summary>
+ /// Adds the log target.
+ /// </summary>
+ /// <param name="target">The target.</param>
+ /// <param name="name">The name.</param>
+ private void AddLogTarget(Target target, string name)
+ {
+ var config = NLog.LogManager.Configuration;
+
+ config.RemoveTarget(name);
+
+ target.Name = name;
+ config.AddTarget(name, target);
+
+ var level = _kernel.Configuration.EnableDebugLevelLogging ? LogLevel.Debug : LogLevel.Info;
+
+ var rule = new LoggingRule("*", level, target);
+ config.LoggingRules.Add(rule);
+
+ NLog.LogManager.Configuration = config;
+ }
+
+ /// <summary>
+ /// Removes the log target.
+ /// </summary>
+ /// <param name="name">The name.</param>
+ private void RemoveLogTarget(string name)
+ {
+ var config = NLog.LogManager.Configuration;
+
+ config.RemoveTarget(name);
+
+ NLog.LogManager.Configuration = config;
+ }
+
+ /// <summary>
+ /// Shuts down.
+ /// </summary>
+ public async void ShutDown()
+ {
+ await Task.Factory.StartNew(Close, CancellationToken.None, TaskCreationOptions.None, _uiThread);
+ }
+
+ }
+
+}