##// END OF EJS Templates
Fixed component container
Fixed component container

File last commit:

r194:d45bdf510514 v2
r216:1e082fb67a46 v2
Show More
LogChannel.cs
85 lines | 3.3 KiB | text/x-csharp | CSharpLexer
cin
improved log concept
r36 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Implab.Diagnostics {
cin
Interactive tracing...
r48 /// <summary>
/// Канал, через который публикуются события журнала.
/// </summary>
/// <typeparam name="TEvent">Тип событий в канале</typeparam>
/// <remarks>
/// Событиями журнала могут быть любые типы, например строки, в которых будет передаваться
/// информация, или структуры с набором полей, описывающих важность, текст и другую информацию.
/// </remarks>
cin
improved log concept
r36 public class LogChannel<TEvent> {
static LogChannel<TEvent> _default = new LogChannel<TEvent>();
cin
Interactive tracing...
r48 /// <summary>
/// Канал по-умолчанию для событий типа <typeparam name="TEvent"/>.
/// </summary>
cin
improved log concept
r36 public static LogChannel<TEvent> Default {
get {
return _default;
}
}
cin
Interactive tracing...
r48 /// <summary>
/// Событие появление новой записи в журнале, на это событие подписываются слушатели.
/// </summary>
cin
rewritten tracing
r92 public event EventHandler<LogEventArgs<TEvent>> Events;
cin
Interactive tracing...
r48 /// <summary>
/// Имя канала, полезно для отображения в журнале
/// </summary>
public string Name {
get;
private set;
}
cin
improved log concept
r36
cin
Interactive tracing...
r48 /// <summary>
/// Создает журнал, имя типа событий назначается в качетве имени канала.
/// </summary>
public LogChannel()
: this(null) {
}
/// <summary>
/// Содает канал с указанным именем.
/// </summary>
/// <param name="name">Имя канала.</param>
public LogChannel(string name) {
if (String.IsNullOrEmpty(name))
name = typeof(TEvent).Name;
Name = name;
}
/// <summary>
/// Отправляет запись журнала через канал подписчикам.
/// </summary>
/// <param name="data">Запись журнала.</param>
/// <remarks>
/// Контекст трассировки от которого рассылается сообщение определяется автоматически из текущего потока.
/// </remarks>
cin
improved log concept
r36 public void LogEvent(TEvent data) {
var t = Events;
cin
rewritten tracing
r92 if (t != null) {
var traceContext = TraceContext.Instance;
t(
this,
new LogEventArgs<TEvent>(
data,
cin
working on diagnostics
r194 this,
cin
rewritten tracing
r92 traceContext.ThreadId,
traceContext.CurrentOperation,
traceContext.CurrentOperation.Duration
)
);
}
cin
working version of diagnostics logging
r37 }
cin
working on diagnostics
r194
public override string ToString() {
return Name;
}
cin
improved log concept
r36 }
}