本文整理匯總了C#中NLog.Config.LoggingRule.EnableLoggingForLevel方法的典型用法代碼示例。如果您正苦於以下問題:C# LoggingRule.EnableLoggingForLevel方法的具體用法?C# LoggingRule.EnableLoggingForLevel怎麽用?C# LoggingRule.EnableLoggingForLevel使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類NLog.Config.LoggingRule
的用法示例。
在下文中一共展示了LoggingRule.EnableLoggingForLevel方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: EnableDebugConsoleOutput
public static void EnableDebugConsoleOutput()
{
if (IsDebugConsoleOutputEnabled) {
return;
}
LoggingConfiguration config = LogManager.Configuration;
ConsoleTarget consoleTarget = new ConsoleTarget() { Name = "consoleDebugOutput" };
LoggingRule consoleRule = new LoggingRule("*", consoleTarget);
consoleRule.EnableLoggingForLevel(LogLevel.Trace);
consoleRule.EnableLoggingForLevel(LogLevel.Debug);
config.AddTarget(consoleTarget);
config.LoggingRules.Add(consoleRule);
IsDebugConsoleOutputEnabled = true;
}
示例2: ConfigureLogging
private static void ConfigureLogging(bool enableVerboseLogging)
{
var config = new LoggingConfiguration();
var consoleTarget = new ColoredConsoleTarget();
config.AddTarget("console", consoleTarget);
consoleTarget.Layout = "> ${message}";
var rule1 = new LoggingRule("*", LogLevel.Info, consoleTarget);
if (enableVerboseLogging)
{
rule1.EnableLoggingForLevel(LogLevel.Trace);
rule1.EnableLoggingForLevel(LogLevel.Debug);
}
config.LoggingRules.Add(rule1);
LogManager.Configuration = config;
}
示例3: ChangeRuleMinLevel
private static void ChangeRuleMinLevel(LoggingRule rule, LogLevel minLevel)
{
/*
* Based on how the LoggingLevel initializes its logging levels when given a minLevel,
* but because LogLevel.MinLevel and LogLevel.MaxLevel are not publically accessible,
* their current values are hardcoded. TODO: This is fragile!
*/
for (var i = LogLevel.Trace.Ordinal; i < minLevel.Ordinal; i++)
{
rule.DisableLoggingForLevel(LogLevel.FromOrdinal(i));
}
for (var i = minLevel.Ordinal; i <= LogLevel.Fatal.Ordinal; i++)
{
rule.EnableLoggingForLevel(LogLevel.FromOrdinal(i));
}
LogManager.ReconfigExistingLoggers();
}
示例4: ParseLoggerElement
/// <summary>
/// Parse {Logger} xml element
/// </summary>
/// <param name="loggerElement"></param>
/// <param name="rulesCollection">Rules are added to this parameter.</param>
private void ParseLoggerElement(NLogXmlElement loggerElement, IList<LoggingRule> rulesCollection)
{
loggerElement.AssertName("logger");
var namePattern = loggerElement.GetOptionalAttribute("name", "*");
var enabled = loggerElement.GetOptionalBooleanAttribute("enabled", true);
if (!enabled)
{
InternalLogger.Debug("The logger named '{0}' are disabled");
return;
}
var rule = new LoggingRule();
string appendTo = loggerElement.GetOptionalAttribute("appendTo", null);
if (appendTo == null)
{
appendTo = loggerElement.GetOptionalAttribute("writeTo", null);
}
rule.LoggerNamePattern = namePattern;
if (appendTo != null)
{
foreach (string t in appendTo.Split(','))
{
string targetName = t.Trim();
Target target = FindTargetByName(targetName);
if (target != null)
{
rule.Targets.Add(target);
}
else
{
throw new NLogConfigurationException("Target " + targetName + " not found.");
}
}
}
rule.Final = loggerElement.GetOptionalBooleanAttribute("final", false);
string levelString;
if (loggerElement.AttributeValues.TryGetValue("level", out levelString))
{
LogLevel level = LogLevel.FromString(levelString);
rule.EnableLoggingForLevel(level);
}
else if (loggerElement.AttributeValues.TryGetValue("levels", out levelString))
{
levelString = CleanSpaces(levelString);
string[] tokens = levelString.Split(',');
foreach (string s in tokens)
{
if (!string.IsNullOrEmpty(s))
{
LogLevel level = LogLevel.FromString(s);
rule.EnableLoggingForLevel(level);
}
}
}
else
{
int minLevel = 0;
int maxLevel = LogLevel.MaxLevel.Ordinal;
string minLevelString;
string maxLevelString;
if (loggerElement.AttributeValues.TryGetValue("minLevel", out minLevelString))
{
minLevel = LogLevel.FromString(minLevelString).Ordinal;
}
if (loggerElement.AttributeValues.TryGetValue("maxLevel", out maxLevelString))
{
maxLevel = LogLevel.FromString(maxLevelString).Ordinal;
}
for (int i = minLevel; i <= maxLevel; ++i)
{
rule.EnableLoggingForLevel(LogLevel.FromOrdinal(i));
}
}
foreach (var child in loggerElement.Children)
{
switch (child.LocalName.ToUpper(CultureInfo.InvariantCulture))
{
case "FILTERS":
this.ParseFilters(rule, child);
break;
case "LOGGER":
this.ParseLoggerElement(child, rule.ChildRules);
break;
//.........這裏部分代碼省略.........
示例5: ParseLoggerElement
private void ParseLoggerElement(XmlReader reader, ICollection<LoggingRule> rulesCollection)
{
LoggingRule rule = new LoggingRule();
string namePattern = this.GetCaseInsensitiveAttribute(reader, "name", "*");
string appendTo = this.GetCaseInsensitiveAttribute(reader, "appendTo", null);
if (appendTo == null)
{
appendTo = this.GetCaseInsensitiveAttribute(reader, "writeTo", null);
}
rule.LoggerNamePattern = namePattern;
if (appendTo != null)
{
foreach (string t in appendTo.Split(','))
{
string targetName = t.Trim();
Target target = FindTargetByName(targetName);
if (target != null)
{
rule.Targets.Add(target);
}
else
{
throw new NLogConfigurationException("Target " + targetName + " not found.");
}
}
}
rule.Final = false;
if (this.GetCaseInsensitiveAttribute(reader, "final", "false") == "true")
{
rule.Final = true;
}
string levelString;
if (this.TryGetCaseInsensitiveAttribute(reader, "level", out levelString))
{
LogLevel level = LogLevel.FromString(levelString);
rule.EnableLoggingForLevel(level);
}
else if (this.TryGetCaseInsensitiveAttribute(reader, "levels", out levelString))
{
levelString = this.CleanWhitespace(levelString);
string[] tokens = levelString.Split(',');
foreach (string s in tokens)
{
if (!string.IsNullOrEmpty(s))
{
LogLevel level = LogLevel.FromString(s);
rule.EnableLoggingForLevel(level);
}
}
}
else
{
int minLevel = 0;
int maxLevel = LogLevel.MaxLevel.Ordinal;
string minLevelString;
string maxLevelString;
if (this.TryGetCaseInsensitiveAttribute(reader, "minLevel", out minLevelString))
{
minLevel = LogLevel.FromString(minLevelString).Ordinal;
}
if (this.TryGetCaseInsensitiveAttribute(reader, "maxLevel", out maxLevelString))
{
maxLevel = LogLevel.FromString(maxLevelString).Ordinal;
}
for (int i = minLevel; i <= maxLevel; ++i)
{
rule.EnableLoggingForLevel(LogLevel.FromOrdinal(i));
}
}
if (!reader.IsEmptyElement)
{
while (this.MoveToNextElement(reader))
{
switch (reader.LocalName.ToLower(CultureInfo.InvariantCulture))
{
case "filters":
this.ParseFilters(rule, reader);
break;
case "logger":
this.ParseLoggerElement(reader, rule.ChildRules);
break;
default:
reader.Skip();
break;
}
}
}
//.........這裏部分代碼省略.........
示例6: SetLogLevelForRule
private void SetLogLevelForRule(LoggingRule rule, LogLevel activeLogLevel)
{
// Reset all log levels to off
for (int i = MinLogLevel; i <= MaxLogLevel; i++)
{
rule.DisableLoggingForLevel(LogLevel.FromOrdinal(i));
}
// Enable the active log level and all levels numerically higher
for (int i = activeLogLevel.GetHashCode(); i <= MaxLogLevel; i++)
{
rule.EnableLoggingForLevel(LogLevel.FromOrdinal(i));
}
InternalLogger.Debug("*** Setting active log level for " + _logger.Name + " to " + activeLogLevel.Name);
}
示例7: EnableWarningLogging
public static void EnableWarningLogging()
{
if (IsWarningLoggingEnabled) {
return;
}
LoggingConfiguration config = LogManager.Configuration;
FileTarget warningTarget = new FileTarget() {
Name = "fileWarnings",
Layout = "${longdate} | ${level:uppercase=true} | ${logger} | ${message}",
FileName = BaseLogDirectory + @"\Warning\warning.log",
ArchiveFileName = BaseLogDirectory + @"\MobiBot\Warning\warning.{###}.txt",
ArchiveEvery = FileArchivePeriod.Day,
ArchiveNumbering = ArchiveNumberingMode.Rolling,
MaxArchiveFiles = 30,
NetworkWrites = true,
KeepFileOpen = true
};
LoggingRule warningRule = new LoggingRule("*", warningTarget);
warningRule.EnableLoggingForLevel(LogLevel.Warn);
config.AddTarget(warningTarget);
config.LoggingRules.Add(warningRule);
IsWarningLoggingEnabled = true;
}
示例8: ApplyLogLevel
private void ApplyLogLevel(LoggingRule rule, IList<LogLevel> levels)
{
foreach (var level in rule.Levels)
rule.DisableLoggingForLevel(level);
foreach (var level in levels)
rule.EnableLoggingForLevel(level);
}
示例9: MvcApplication_BeginRequest
void MvcApplication_BeginRequest(object sender, EventArgs e)
{
try
{
if (HttpContext.Current.Request.QueryString["vm"] != null && Convert.ToInt32(HttpContext.Current.Request.QueryString["vm"]) == 10)
{
MemoryTarget _logTarget = null;
_loggerName = Guid.NewGuid().ToString().Replace("-", string.Empty);
HttpContext.Current.Items.Add("LoggerName", _loggerName);
_logTarget = new MemoryTarget();
_logTarget.Name = _loggerName.ToString();
LoggingRule rule = new LoggingRule(_loggerName, _logTarget);
rule.EnableLoggingForLevel(LogLevel.Debug);
rule.EnableLoggingForLevel(LogLevel.Trace);
rule.EnableLoggingForLevel(LogLevel.Info);
rule.EnableLoggingForLevel(LogLevel.Warn);
rule.EnableLoggingForLevel(LogLevel.Error);
rule.EnableLoggingForLevel(LogLevel.Fatal);
LogManager.Configuration.LoggingRules.Add(rule);
LogManager.Configuration.Reload();
}
}
catch (Exception ex)
{
LogEventInfo info = new LogEventInfo(LogLevel.Error, ECMSSettings.DEFAULT_LOGGER, ex.ToString());
ECMSLogger.Instance.Log(info);
}
}