bullet3/LinearMath/quickprof.cpp
2006-05-25 19:18:29 +00:00

46 lines
2.4 KiB
C++

/************************************************************************
* QuickProf *
* Copyright (C) 2006 *
* Tyler Streeter tylerstreeter@gmail.com *
* All rights reserved. *
* Web: http://quickprof.sourceforge.net *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of EITHER: *
* (1) The GNU Lesser General Public License as published by the Free *
* Software Foundation; either version 2.1 of the License, or (at *
* your option) any later version. The text of the GNU Lesser *
* General Public License is included with this library in the *
* file license-LGPL.txt. *
* (2) The BSD-style license that is included with this library in *
* the file license-BSD.txt. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the files *
* license-LGPL.txt and license-BSD.txt for more details. *
************************************************************************/
// Please visit the project website (http://quickprof.sourceforge.net)
// for usage instructions.
// Credits: The Clock class was inspired by the Timer classes in
// Ogre (www.ogre3d.org).
#include "quickprof.h"
#ifdef USE_QUICKPROF
// Note: We must declare these private static variables again here to
// avoid link errors.
bool Profiler::mEnabled = false;
hidden::Clock Profiler::mClock;
unsigned long int Profiler::mCurrentCycleStartMicroseconds = 0;
unsigned long int Profiler::mLastCycleDurationMicroseconds = 0;
std::map<std::string, hidden::ProfileBlock*> Profiler::mProfileBlocks;
std::ofstream Profiler::mOutputFile;
bool Profiler::mFirstFileOutput = true;
Profiler::BlockTimingMethod Profiler::mFileOutputMethod;
unsigned long int Profiler::mCycleNumber = 0;
#endif //USE_QUICKPROF