view Implab/Diagnostics/ConsoleTraceListener.cs @ 40:fe33f4e02ad5

improved tracing added text listeners (file,console)
author cin
date Tue, 15 Apr 2014 17:52:09 +0400
parents 313f708a50e9
children 7c2369f580b8
line wrap: on
line source

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Implab.Diagnostics {
    public class ConsoleTraceListener: TextListenerBase {

        static readonly object _consoleLock = new object();

        protected override void WriteEntry(TraceContext context, EventText text) {
            var msg = new StringBuilder();

            for (int i = 0; i < text.indent; i++)
                msg.Append("  ");
            msg.AppendFormat("[{0}]: {1}", context.ThreadId, text.content);

            lock (_consoleLock) {
                Console.ForegroundColor = (ConsoleColor)(context.ThreadId % 15 + 1);
                Console.WriteLine(msg.ToString());
            }
        }
    }
}