Mercurial > pub > ImplabNet
view Implab/Diagnostics/TextFileListener.cs @ 45:d10034588e38 interactive logger
initial work on interactive logger
author | cin |
---|---|
date | Thu, 17 Apr 2014 03:05:53 +0400 |
parents | fe33f4e02ad5 |
children | 7c2369f580b8 |
line wrap: on
line source
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Text; namespace Implab.Diagnostics { public class TextFileListener: TextListenerBase { readonly TextWriter m_textWriter; public TextFileListener(string fileName) { m_textWriter = File.CreateText(fileName); m_textWriter.WriteLine("LOG {0}", DateTime.Now); Register(this); } 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 (m_textWriter) { if (!IsDisposed) { m_textWriter.WriteLine(msg.ToString()); m_textWriter.Flush(); } } } protected override void Dispose(bool disposing) { base.Dispose(disposing); if (disposing) { lock (m_textWriter) { Safe.Dispose(m_textWriter); } } } } }