Mercurial > pub > ImplabNet
view Implab/Diagnostics/ActivityScope.cs @ 262:f1696cdc3d7a v3 v3.0.8
Added IInitializable.Initialize() overload
Added IRunnable.Start(), IRunnable.Start() overloads
Fixed cancellation of the current operation when Stop() is called
More tests
author | cin |
---|---|
date | Mon, 16 Apr 2018 02:12:39 +0300 |
parents | 34df34841225 |
children |
line wrap: on
line source
using System; using System.Diagnostics; namespace Implab.Diagnostics { public class ActivityScope : IDisposable { readonly TraceSource m_source; readonly Guid m_prevId; readonly string m_activity; readonly int m_code; internal ActivityScope(TraceSource source, Guid prevId, int code, string activity) { m_source = source; m_prevId = prevId; m_code = code; m_activity = activity; } public void Dispose() { if (Trace.CorrelationManager.ActivityId != m_prevId) m_source.TraceTransfer(m_code, "Transfer", m_prevId); m_source.TraceEvent(TraceEventType.Stop, 0, m_activity); Trace.CorrelationManager.ActivityId = m_prevId; } } }