aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common.Implementations/Logging/NlogManager.cs
diff options
context:
space:
mode:
authorEric Reed <ebr@mediabrowser3.com>2013-03-04 11:59:57 -0500
committerEric Reed <ebr@mediabrowser3.com>2013-03-04 11:59:57 -0500
commite5a78ba5bf8f0e181c9d1991ba37cb9116d32c1d (patch)
treef03acbc59d8799f9dc861b8b77ab4334082c4503 /MediaBrowser.Common.Implementations/Logging/NlogManager.cs
parent62448129a66f50b6ac2874c6da514399f974340e (diff)
parentda535db6554e1ca6610f247b02b3a0391e8f1f02 (diff)
Merge branch 'master' of https://github.com/MediaBrowser/MediaBrowser
Diffstat (limited to 'MediaBrowser.Common.Implementations/Logging/NlogManager.cs')
-rw-r--r--MediaBrowser.Common.Implementations/Logging/NlogManager.cs46
1 files changed, 37 insertions, 9 deletions
diff --git a/MediaBrowser.Common.Implementations/Logging/NlogManager.cs b/MediaBrowser.Common.Implementations/Logging/NlogManager.cs
index 1e525137c..c5296dcfb 100644
--- a/MediaBrowser.Common.Implementations/Logging/NlogManager.cs
+++ b/MediaBrowser.Common.Implementations/Logging/NlogManager.cs
@@ -1,4 +1,5 @@
-using MediaBrowser.Model.Logging;
+using System.Linq;
+using MediaBrowser.Model.Logging;
using NLog;
using NLog.Config;
using NLog.Targets;
@@ -56,23 +57,21 @@ namespace MediaBrowser.Common.Implementations.Logging
logFile.FileName = path;
logFile.Layout = "${longdate}, ${level}, ${logger}, ${message}";
- AddLogTarget(logFile, "ApplicationLogFile", level);
+ RemoveTarget("ApplicationLogFile");
+ logFile.Name = "ApplicationLogFile";
+
+ AddLogTarget(logFile, level);
}
/// <summary>
/// Adds the log target.
/// </summary>
/// <param name="target">The target.</param>
- /// <param name="name">The name.</param>
/// <param name="level">The level.</param>
- private void AddLogTarget(Target target, string name, LogSeverity level)
+ private void AddLogTarget(Target target, LogSeverity level)
{
var config = LogManager.Configuration;
-
- config.RemoveTarget(name);
-
- target.Name = name;
- config.AddTarget(name, target);
+ config.AddTarget(target.Name, target);
var rule = new LoggingRule("*", GetLogLevel(level), target);
config.LoggingRules.Add(rule);
@@ -81,6 +80,35 @@ namespace MediaBrowser.Common.Implementations.Logging
}
/// <summary>
+ /// Removes the target.
+ /// </summary>
+ /// <param name="name">The name.</param>
+ public void RemoveTarget(string name)
+ {
+ var config = LogManager.Configuration;
+
+ var target = config.FindTargetByName(name);
+
+ if (target != null)
+ {
+ foreach (var rule in config.LoggingRules.ToList())
+ {
+ var contains = rule.Targets.Contains(target);
+
+ rule.Targets.Remove(target);
+
+ if (contains)
+ {
+ config.LoggingRules.Remove(rule);
+ }
+ }
+
+ config.RemoveTarget(name);
+ LogManager.Configuration = config;
+ }
+ }
+
+ /// <summary>
/// Gets the logger.
/// </summary>
/// <param name="name">The name.</param>