Mercurial > pub > ImplabNet
view Implab/Diagnostics/TextFileListener.cs @ 240:fa6cbf4d8841 v3
refactoring, moving to dotnercore, simplifying promises
author | cin |
---|---|
date | Tue, 23 Jan 2018 19:39:21 +0300 |
parents | 6efb77590b15 |
children |
line wrap: on
line source
using System; using System.IO; using System.Text; namespace Implab.Diagnostics { public class TextFileListener: ListenerBase { readonly TextWriter m_textWriter; readonly object m_lock = new object(); public TextFileListener(string fileName) { m_textWriter = File.CreateText(fileName); m_textWriter.WriteLine("LOG {0}", DateTime.Now); } #region implemented abstract members of ListenerBase 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}]+{3}ms:{1}: {2}", args.ThreadId, args.Channel, entry, args.OperationTimeOffset); lock (m_lock) { if (!IsDisposed) { // тут гарантировано еще не освобожден m_textWriter m_textWriter.WriteLine(msg); m_textWriter.Flush(); } } } #endregion protected override void Dispose(bool disposing) { base.Dispose(disposing); if (disposing) { // IsDisposed = true lock (m_lock) { Safe.Dispose(m_textWriter); } } } } }