Sirikata
|
00001 /* Sirikata 00002 * TimeProfiler.hpp 00003 * 00004 * Copyright (c) 2009, Ewen Cheslack-Postava 00005 * All rights reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions are 00009 * met: 00010 * * Redistributions of source code must retain the above copyright 00011 * notice, this list of conditions and the following disclaimer. 00012 * * Redistributions in binary form must reproduce the above copyright 00013 * notice, this list of conditions and the following disclaimer in 00014 * the documentation and/or other materials provided with the 00015 * distribution. 00016 * * Neither the name of Sirikata nor the names of its contributors may 00017 * be used to endorse or promote products derived from this software 00018 * without specific prior written permission. 00019 * 00020 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 00021 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 00022 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00023 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 00024 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00025 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00026 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00027 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00028 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00029 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00030 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00031 */ 00032 00033 #ifndef _SIRIKATA_TIME_PROFILER_HPP_ 00034 #define _SIRIKATA_TIME_PROFILER_HPP_ 00035 00036 #include <sirikata/core/util/Timer.hpp> 00037 00038 namespace Sirikata { 00039 00040 class Context; 00041 00049 class SIRIKATA_EXPORT TimeProfiler { 00050 public: 00051 struct SIRIKATA_EXPORT Stage { 00052 ~Stage(); 00053 00054 void started(); 00055 void finished(); 00056 00057 String name() const; 00058 Duration avg() const; 00059 Duration minimum() const; 00060 Duration maximum() const; 00061 uint64 its() const; 00062 00063 void report(const String& indent) const; 00064 private: 00065 friend class TimeProfiler; 00066 00067 Stage(TimeProfiler* parent, const String& name); 00068 void invalidate(); 00069 00070 TimeProfiler* mParent; 00071 String mName; 00072 00073 Time mStartTime; 00074 00075 Duration mMinimum; 00076 Duration mMaximum; 00077 Duration mSum; 00078 uint64 mIts; 00079 00080 bool mValid; 00081 }; 00082 00083 TimeProfiler(const Context* ctx, const String& name); 00084 ~TimeProfiler(); 00085 00091 Stage* addStage(const String& name); 00097 Stage* addStage(const String& group_name, const String& name); 00098 00099 void report() const; 00100 private: 00101 friend class Stage; 00102 00103 void remove(Stage* stage); 00104 00105 const Context* mContext; 00106 String mName; 00107 typedef std::vector<Stage*> StageList; 00108 typedef std::map<String, StageList> GroupMap; 00109 GroupMap mGroups; 00110 StageList mFreeStages; 00111 }; // class TimeProfiler 00112 00113 } // namespace Sirikata 00114 00115 #endif //_SIRIKATA_TIME_PROFILER_HPP_