本文整理匯總了C#中log4net.Core.LoggingEvent.First方法的典型用法代碼示例。如果您正苦於以下問題:C# LoggingEvent.First方法的具體用法?C# LoggingEvent.First怎麽用?C# LoggingEvent.First使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類log4net.Core.LoggingEvent
的用法示例。
在下文中一共展示了LoggingEvent.First方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: SendBuffer
protected override void SendBuffer(LoggingEvent[] events)
{
var newEvents = events
.ToList()
.Where(ev => Evaluator.IsTriggeringEvent(ev))
.ToList();
// Se è passato l'intervallo prende il primo
if (FlushInterval.TotalMilliseconds >= 0 && DateTime.Now - _lastFlush > FlushInterval)
{
newEvents = new List<LoggingEvent> {events.First()};
// Se c'è specificato un filtro allora filtra
if (!string.IsNullOrEmpty(IgnoreIfWordsInSubjectOrBody))
{
var items = IgnoreIfWordsInSubjectOrBody.Split(',').Select(el => el.ToLower()).ToList();
// Se una parola è contenuta nell'oggetto o nel testo del messaggio viene scartato il messaggio
var filteredEvents = new List<LoggingEvent>();
foreach (var loggingEvent in newEvents)
{
var subject = RenderSubject(loggingEvent);
var message = loggingEvent.RenderedMessage;
if (!items.Any(el => subject.ToLower().Contains(el) && !message.ToLower().Contains(el)))
filteredEvents.Add(loggingEvent);
}
newEvents = filteredEvents;
}
if (newEvents.Count > 0)
{
var subjects = newEvents.Select(RenderSubject);
Subject = string.Join(", ", subjects);
base.SendBuffer(newEvents.ToArray());
_lastFlush = DateTime.Now;
}
}
}