/* This file is part of Raul. Copyright 2007-2012 David Robillard Raul is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Raul 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 General Public License for more details. You should have received a copy of the GNU General Public License along with Raul. If not, see . */ #ifndef RAUL_THREAD_HPP #define RAUL_THREAD_HPP #include "raul/Noncopyable.hpp" namespace Raul { struct ThreadImpl; /** Abstract base class for a thread. * * Extend this and override the _run method to easily create a thread * to perform some task. * * \ingroup raul */ class Thread : Noncopyable { public: virtual ~Thread(); /** Start the thread if it is not already running. * * This is separate from construction to prevent race conditions during * construction of derived classes. */ virtual void start(); /** Stop the thread and block the caller until the thread exits. * * This sets _exit_flag to true, derived classes must ensure they actually * exit when this occurs. */ virtual void join(); /** Set the scheduling policy for this thread. * @return True on success. */ virtual bool set_scheduling(bool realtime, unsigned priority); protected: /** Construct a thread. * * Note this does not actually start a thread to prevent race conditions * during construction. To actually begin execution, call start(). */ explicit Thread(); /** Thread function to execute. * * This is called once on start, and terminated on stop. * Implementations likely want to put some infinite loop here. * * When _exit_flag becomes true (via a call to stop()) the loop * should exit. */ virtual void _run() {} private: static void* _static_run(void* me); ThreadImpl* _impl; bool _thread_exists; protected: bool _exit_flag; }; } // namespace Raul #endif // RAUL_THREAD_HPP