##// END OF EJS Templates
DRAFT: refactoring, adding cancelation token
DRAFT: refactoring, adding cancelation token

File last commit:

r134:04d4c92d0f28 v2
r143:16f926ee499d 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);
}
}
}
}