view Implab/Diagnostics/LogicalOperationScope.cs @ 278:6691aff01de1 v3

Implab: added XmlDefaultSeializer (SerializersPool is now obsolete) Implab.ServiceHost: rewritten TypeReference (added support for nested types), stable API
author cin
date Thu, 03 May 2018 09:59:44 +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);
        }
    }
}