From 92235fb259b0ebdfc99859c2c95fe1f8c163f411 Mon Sep 17 00:00:00 2001 From: Clyne Sullivan Date: Tue, 8 Nov 2016 20:09:05 -0500 Subject: trying out distortos --- include/distortos/SoftwareTimer.hpp | 130 ++++++++++++++++++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 include/distortos/SoftwareTimer.hpp (limited to 'include/distortos/SoftwareTimer.hpp') diff --git a/include/distortos/SoftwareTimer.hpp b/include/distortos/SoftwareTimer.hpp new file mode 100644 index 0000000..c10060c --- /dev/null +++ b/include/distortos/SoftwareTimer.hpp @@ -0,0 +1,130 @@ +/** + * \file + * \brief SoftwareTimer class header + * + * \author Copyright (C) 2015 Kamil Szczygiel http://www.distortec.com http://www.freddiechopin.info + * + * \par License + * This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not + * distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ + +#ifndef INCLUDE_DISTORTOS_SOFTWARETIMER_HPP_ +#define INCLUDE_DISTORTOS_SOFTWARETIMER_HPP_ + +#include "distortos/TickClock.hpp" + +namespace distortos +{ + +/** + * \brief SoftwareTimer class is an abstract interface for software timers + * + * \ingroup softwareTimers + */ + +class SoftwareTimer +{ +public: + + /** + * \brief SoftwareTimer's destructor + */ + + virtual ~SoftwareTimer() = 0; + + /** + * \return true if the timer is running, false otherwise + */ + + virtual bool isRunning() const = 0; + + /** + * \brief Starts the timer. + * + * \note The duration will never be shorter, so one additional tick is always added to the duration. + * + * \param [in] duration is the duration after which the function will be executed + * + * \return 0 on success, error code otherwise + */ + + int start(TickClock::duration duration); + + /** + * \brief Starts the timer. + * + * \note The duration must not be shorter, so one additional tick is always added to the duration. + * + * \tparam Rep is type of tick counter + * \tparam Period is std::ratio type representing the tick period of the clock, in seconds + * + * \param [in] duration is the duration after which the function will be executed + * + * \return 0 on success, error code otherwise + */ + + template + int start(const std::chrono::duration duration) + { + return start(std::chrono::duration_cast(duration)); + } + + /** + * \brief Starts the timer. + * + * \param [in] timePoint is the time point at which the function will be executed + * + * \return 0 on success, error code otherwise + */ + + virtual int start(TickClock::time_point timePoint) = 0; + + /** + * \brief Starts the timer. + * + * \tparam Duration is a std::chrono::duration type used to measure duration + * + * \param [in] timePoint is the time point at which the function will be executed + * + * \return 0 on success, error code otherwise + */ + + template + int start(const std::chrono::time_point timePoint) + { + return start(std::chrono::time_point_cast(timePoint)); + } + + /** + * \brief Stops the timer. + * + * \return 0 on success, error code otherwise + */ + + virtual int stop() = 0; + +protected: + + /** + * \brief Software timer's function runner + * + * \param [in] softwareTimer is a reference to SoftwareTimer object that is being run + */ + + static void softwareTimerRunner(SoftwareTimer& softwareTimer); + +private: + + /** + * \brief "Run" function of software timer + * + * This should be overridden by derived classes. + */ + + virtual void run() = 0; +}; + +} // namespace distortos + +#endif // INCLUDE_DISTORTOS_SOFTWARETIMER_HPP_ -- cgit v1.2.3