view Implab/Diagnostics/LogicalOperationScope.cs @ 255:b00441e04738 v3

Adde workaround to the behaviour of the logical operations stack in conjuction with async/await methods
author cin
date Wed, 04 Apr 2018 15:38:48 +0300
parents 34df34841225
children
line wrap: on
line source

using System;
using System.Diagnostics;

namespace Implab.Diagnostics {
    public class LogicalOperationScope : IDisposable {
        readonly TraceSource m_source;

        readonly LogicalOperation m_operation;

        internal LogicalOperationScope(TraceSource source, LogicalOperation operation) {
            m_source = source;
            m_operation = operation;
        }

        public void Dispose() {
            m_operation.OperationStopwatch.Stop();
            Trace.CorrelationManager.StopLogicalOperation();
            m_source.TraceData(TraceEventType.Information, TraceEventCodes.StopLogicalOperation, m_operation);
        }
    }
}