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;
        }
    }
}