00001 /* 00002 SagaEngine library 00003 Copyright (c) 2002-2006 Skalden Studio AS 00004 00005 This software is provided 'as-is', without any express or implied 00006 warranty. In no event will the authors be held liable for any 00007 damages arising from the use of this software. 00008 00009 Permission is granted to distribute the library under the terms of the 00010 Q Public License version 1.0. Be sure to read and understand the license 00011 before using the library. It should be included here, or you may read it 00012 at http://www.trolltech.com/products/qt/licenses/licensing/qpl 00013 00014 The original version of this library can be located at: 00015 http://www.sagaengine.com/ 00016 00017 Rune Myrland 00018 rune@skalden.com 00019 */ 00020 00021 00022 #ifndef StopWatch_hpp 00023 #define StopWatch_hpp 00024 00025 namespace se_core { 00026 class _SeCoreExport StopWatch { 00027 public: 00028 StopWatch(); 00029 virtual ~StopWatch() {} 00030 virtual long currentSystemTime(); 00031 virtual float systemTimeAsMillis(long t) { return static_cast<float>(t); } 00032 00033 long systemTimeUsed(int n) { 00034 return stopTime[n] - startTime[n]; 00035 } 00036 00037 float millisUsed(int n) { 00038 return systemTimeAsMillis(systemTimeUsed(n)); 00039 } 00040 00041 float maxMillisUsed(int n) { 00042 return systemTimeAsMillis(maxUsed[n]); 00043 } 00044 00045 void setN(int n) { 00046 (*this).n = n; 00047 } 00048 00049 char* millisUsedAsString(); 00050 00051 void start() { 00052 startTime[n] = currentSystemTime(); 00053 } 00054 00055 void stop() { 00056 stopTime[n] = currentSystemTime(); 00057 if(systemTimeUsed(n) > maxUsed[n] || (systemTimeAsMillis(lastMaxUsed[n]) < systemTimeAsMillis(stopTime[n]) - 1000)) { 00058 lastMaxUsed[n] = stopTime[n]; 00059 maxUsed[n] = systemTimeUsed(n); 00060 } 00061 ++n; 00062 } 00063 00064 00065 private: 00066 long startTime[10], stopTime[10]; 00067 long maxUsed[10], lastMaxUsed[10]; 00068 int n; 00069 }; 00070 00071 } 00072 00073 #endif
Home Page | SagaEngine trunk (updated nightly) reference generated Sun Dec 2 20:06:12 2007 by Doxygen version 1.3.9.1.