fsfw/timemanager/Stopwatch.h

72 lines
2.1 KiB
C
Raw Permalink Normal View History

2020-04-08 19:33:01 +02:00
#ifndef FRAMEWORK_TIMEMANAGER_STOPWATCH_H_
#define FRAMEWORK_TIMEMANAGER_STOPWATCH_H_
#include <framework/timemanager/Clock.h>
enum class StopwatchDisplayMode {
MILLIS,
SECONDS
};
/**
2020-05-29 17:43:06 +02:00
* @brief Simple Stopwatch implementation to measure elapsed time
2020-04-08 19:33:01 +02:00
* @details
* This class can be used to measure elapsed times. It also displays elapsed
* times automatically on destruction if not explicitely deactivated in the
2020-05-29 17:43:06 +02:00
* constructor. The default time format is the elapsed time in miliseconds
* in seconds as a double.
* @author R. Mueller
2020-04-08 19:33:01 +02:00
*/
class Stopwatch {
public:
/**
* Default constructor. Call "Stopwatch stopwatch" without brackets if
* no parameters are required!
* @param displayOnDestruction If set to true, displays measured time on
* object destruction
2020-05-29 17:43:06 +02:00
* @param displayMode Display format is either MS rounded or MS as double
* format
2020-04-08 19:33:01 +02:00
* @param outputPrecision If using double format, specify precision here.
*/
Stopwatch(bool displayOnDestruction = true, StopwatchDisplayMode displayMode
= StopwatchDisplayMode::MILLIS);
virtual~ Stopwatch();
/**
* Caches the start time
*/
void start();
/**
* Calculates the elapsed time since start and returns it
* @return elapsed time in milliseconds (rounded)
*/
2020-06-04 13:01:59 +02:00
dur_millis_t stop();
2020-05-29 17:43:06 +02:00
/**
* Calculates the elapsed time since start and returns it
* @return elapsed time in seconds (double precision)
*/
2020-06-04 13:01:59 +02:00
dur_seconds_t stopSeconds();
2020-04-08 19:33:01 +02:00
/**
* Displays the elapsed times on the osstream, depending on internal display
* mode.
*/
void display();
StopwatchDisplayMode getDisplayMode() const;
void setDisplayMode(StopwatchDisplayMode displayMode);
2020-05-29 17:43:06 +02:00
bool displayOnDestruction = true;
2020-04-08 19:33:01 +02:00
private:
timeval startTime {0, 0};
timeval elapsedTime {0, 0};
StopwatchDisplayMode displayMode = StopwatchDisplayMode::MILLIS;
2020-05-29 17:43:06 +02:00
2020-04-08 19:33:01 +02:00
void stopInternal();
};
#endif /* FRAMEWORK_TIMEMANAGER_STOPWATCH_H_ */