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