view Implab/Diagnostics/TextFileListener.cs @ 43:7c2369f580b8

improved tracing, TextListenerBase can be bound to logical operation scope.
author cin
date Wed, 16 Apr 2014 10:12:56 +0400
parents fe33f4e02ad5
children e5ec543feee3
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) : base(true) {
            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);
                }
            }
        }

        
    }
}