##// END OF EJS Templates
Added class Trace<T> to manage channels for individual classes, if SomeClass...
Added class Trace<T> to manage channels for individual classes, if SomeClass uses Trace<SomeClass> it sould be marked with TraceSourceAttribute

File last commit:

r134:04d4c92d0f28 v2
r212:a01d9df88d74 v2
Show More
ConsoleTraceListener.cs
22 lines | 668 B | text/x-csharp | CSharpLexer
using System;
using System.Text;
namespace Implab.Diagnostics {
public class ConsoleTraceListener: ListenerBase {
static readonly object _consoleLock = new object();
public override void Write(LogEventArgs args, object entry) {
var msg = new StringBuilder();
for (int i = 0; i < args.Operation.Level; i++)
msg.Append(" ");
msg.AppendFormat("[{0}]: {1}", args.ThreadId, entry);
lock (_consoleLock) {
Console.ForegroundColor = (ConsoleColor)(args.ThreadId % 15 + 1);
Console.WriteLine(msg);
}
}
}
}