using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Implab.Diagnostics { public static class Trace { readonly static TraceSource _traceSource = new TraceSource(typeof(T).Name); public static TraceSource TraceSource { get { return _traceSource; } } /// /// Starts the logical operation nested to the current operation nested to the current one. /// [Conditional("TRACE")] public static void StartLogicalOperation() { Trace.CorrelationManager.StartLogicalOperation(); } /// /// Starts the logical operation with the specified name, this name is usefull in logs. /// /// Name. [Conditional("TRACE")] public static void StartLogicalOperation(string name) { Trace.CorrelationManager.StartLogicalOperation(); } /// /// Ends the logical operation and restores the previous one. /// [Conditional("TRACE")] public static void StopLogicalOperation() { Trace.CorrelationManager.StopLogicalOperation(); } /// /// Writes an informational message. /// /// Format. /// Arguments. [Conditional("TRACE")] public static void Log(string format, params object[] arguments) { TraceSource.TraceEvent(TraceEventType.Information, 1, format, arguments); } /// /// Writes a warning message. /// /// Format. /// Arguments. [Conditional("TRACE")] public static void Warn(string format, params object[] arguments) { TraceSource.TraceEvent(TraceEventType.Warning, 1, format, arguments); } [Conditional("TRACE")] public static void Error(string format, params object[] arguments) { TraceSource.TraceEvent(TraceEventType.Error, 1, format, arguments); } [Conditional("TRACE")] public static void Error(Exception err) { TraceSource.TraceData(TraceEventType.Error, 1, err); } } }