##// END OF EJS Templates
Added class Trace<T> to manage channels for individual classes, if SomeClass...
Added class Trace<T> to manage channels for individual classes, if SomeClass uses Trace<SomeClass> it sould be marked with TraceSourceAttribute

File last commit:

r92:4c0e5ef99986 v2
r212:a01d9df88d74 v2
Show More
LogicalOperation.cs
45 lines | 1.2 KiB | text/x-csharp | CSharpLexer
using System;
namespace Implab.Diagnostics {
public class LogicalOperation {
public static readonly LogicalOperation EMPTY = new LogicalOperation("__EMPTY__", null);
readonly LogicalOperation m_parent;
readonly string m_name;
readonly int m_level;
readonly int m_timestamp;
public LogicalOperation()
: this(null, null) {
}
public LogicalOperation(string name, LogicalOperation parent) {
m_name = name ?? String.Empty;
m_parent = parent;
m_level = parent == null ? 0 : parent.Level + 1;
m_timestamp = Environment.TickCount;
}
public int Duration {
get {
var dt = Environment.TickCount - m_timestamp;
return dt < 0 ? int.MaxValue + dt : dt; // handle overflow
}
}
public LogicalOperation Parent {
get {
return m_parent;
}
}
public int Level {
get { return m_level; }
}
public string Name {
get { return m_name; }
}
}
}