// // TimeCounter.cs // // Author: // Lluis Sanchez Gual // // Copyright (c) 2009 Novell, Inc (http://www.novell.com) // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. using System; namespace MonoDevelop.Core.Instrumentation { public interface ITimeTracker: IDisposable { void Trace (string message); void End (); } class DummyTimerCounter: ITimeTracker { public void Trace (string message) { } public void End () { } public void Dispose () { } } class TimeCounter: ITimeTracker { DateTime begin; TimerTraceList traceList; TimerTrace lastTrace; TimerCounter counter; internal TimeCounter (TimerCounter counter) { this.counter = counter; traceList = new TimerTraceList (); Begin (); } internal TimerTraceList TraceList { get { return this.traceList; } } public void Trace (string message) { TimerTrace t = new TimerTrace (); t.Timestamp = DateTime.Now; t.Message = message; if (lastTrace == null) lastTrace = traceList.FirstTrace = t; else { lastTrace.Next = t; lastTrace = t; } traceList.TotalTime = t.Timestamp - traceList.FirstTrace.Timestamp; } internal void Begin () { begin = DateTime.Now; } public void End () { if (counter == null) { Console.WriteLine ("Timer already finished"); return; } traceList.TotalTime = DateTime.Now - begin; if (traceList.TotalTime.TotalSeconds < counter.MinSeconds) counter.RemoveValue (traceList.ValueIndex); else counter.AddTime (traceList.TotalTime); counter = null; } void IDisposable.Dispose () { End (); } } [Serializable] class TimerTraceList { public TimerTrace FirstTrace; public TimeSpan TotalTime; public int ValueIndex; } [Serializable] public class TimerTrace { internal TimerTrace Next; public DateTime Timestamp { get; set; } public string Message { get; set; } } }