42 #include "Teuchos_CTimeMonitor.h"
44 #include "Teuchos_implicit_cast.hpp"
45 #include "Teuchos_StandardCatchMacros.hpp"
46 #include "Teuchos_VerboseObject.hpp"
47 #include "Teuchos_CompilerCodeTweakMacros.hpp"
54 TimerArray_t timerArray;
60 int Teuchos_startTimer(
char timerName[],
int timerID )
68 timerArray.back()->start();
69 return timerArray.size()-1;
73 timerID >= implicit_cast<int>(timerArray.size()), std::logic_error,
74 "Teuchos_startTimer(...): Error, timerID="<<timerID
75 <<
" is >= timerArray.size()="<<timerArray.size()
76 <<
" for timerName=\""<<timerName<<
"\"!"
80 timer->isRunning(), std::logic_error,
81 "Teuchos_startTimer(...): Error, timerID="<<timerID
82 <<
", timerName=\""<<timerName<<
"\" is already running!"
95 void Teuchos_stopTimer(
int timerID )
101 timerID < 0 || timerID >= implicit_cast<int>(timerArray.size()),
103 "Teuchos_stopTimer(...): Error, timerID="<<timerID<<
" is invalid!"
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Macro for throwing an exception with breakpointing to ease debugging.
double stop()
Stop the timer, if the timer is enabled (see disable()).
static RCP< FancyOStream > getDefaultOStream()
Get the default output stream object.
TypeTo implicit_cast(const TypeFrom &t)
Perform an implicit cast of concrete types with the casted object returned by value.
Scope protection wrapper for Teuchos::Time, with timer reporting functionality.
Smart reference counting pointer class for automatic garbage collection.
#define TEUCHOS_STANDARD_CATCH_STATEMENTS(VERBOSE, ERR_STREAM, SUCCESS_FLAG)
Simple macro that catches and reports standard exceptions and other exceptions.
void incrementNumCalls()
Increment the number of times this timer has been called, if the timer is enabled (see disable())...
Replacement for std::vector that is compatible with the Teuchos Memory Management classes...