/* * Copyright (C) 2015 by Multi-Tech Systems * * This file is part of libmts. * * libmts is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 2 of the License, or * (at your option) any later version. * * libmts 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 * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with libmts. If not, see . * */ /*! \file MTS_TimerThread.h \brief An abstract worker thread \date 10MAY13 \author Mike Fiore A platform independent thread that executes a task every x miliseconds. Thread can be paused and unpaused. */ #ifndef _MTS_TIMER_THREAD_H_ #define _MTS_TIMER_THREAD_H_ #include #include #include namespace MTS { //! An abstract worker thread /*! A platform independent worker thread class */ class TimerThread: public Thread { public: ~TimerThread(); //!< Destructs the thread virtual bool isExecuting() const; //!< Returns true if the thread has been started virtual void stopExecution(); //!< Stops running execute() function virtual void restartExecution(); //!< Resumes running execute() function virtual void updateIntervalMillis(uint32_t newMillis); //!< Updates interval to given value protected: explicit TimerThread(const std::string& name); //!< Creates the thread explicit TimerThread(const std::string& name, uint32_t intervalMillis); //!< Creates the thread private: void run(); //!< Abstracts the running of the thread virtual void execute() = 0; //!< main() of the thread which is executed once per interval void init(); //!< Startup code common to all constructors AutoPtr m_apStateLock; //!< Condition Lock bool m_bCurrentlyExecuting; //!< Currently executing flag bool m_bExecutionStopped; //!< Execution stopped flag uint32_t m_ui32IntervalMillis; //!< How often the thread executes }; } #endif