Mercurial > hg > svcore
view base/Profiler.h @ 47:bac8b14ab355
* Add menu for re-adding existing layers
* Fix layer tree window so that it at least approximates correct
* Add bundled operations in command history, for use with things like
multiple consecutive changes to a parameter value
* Disambiguate plugins that happen to have identical descriptions
* Add spectral centroid plugin (could use some parameters!)
* Some other fixes
author | Chris Cannam |
---|---|
date | Fri, 17 Mar 2006 17:38:28 +0000 |
parents | 2fb933f88604 |
children | 39ae3dee27b9 |
line wrap: on
line source
/* -*- c-basic-offset: 4 -*- vi:set ts=8 sts=4 sw=4: */ /* A waveform viewer and audio annotation editor. Chris Cannam, Queen Mary University of London, 2005-2006 This is experimental software. Not for distribution. */ /* This is a modified version of a source file from the Rosegarden MIDI and audio sequencer and notation editor. This file copyright 2000-2006 Chris Cannam and Guillaume Laurent. */ #ifndef _PROFILER_H_ #define _PROFILER_H_ #include "System.h" #include <ctime> #include <sys/time.h> #include <map> #include "RealTime.h" /** * Profiling classes */ /** * The class holding all profiling data * * This class is a singleton */ class Profiles { public: static Profiles* getInstance(); ~Profiles(); void accumulate(const char* id, clock_t time, RealTime rt); void dump(); protected: Profiles(); typedef std::pair<clock_t, RealTime> TimePair; typedef std::pair<int, TimePair> ProfilePair; typedef std::map<const char *, ProfilePair> ProfileMap; typedef std::map<const char *, TimePair> LastCallMap; ProfileMap m_profiles; LastCallMap m_lastCalls; static Profiles* m_instance; }; class Profiler { public: Profiler(const char*, bool showOnDestruct = false); ~Profiler(); void update(); protected: const char* m_c; clock_t m_startCPU; RealTime m_startTime; bool m_showOnDestruct; }; #endif