2015-10-16 02:46:17 +02:00
|
|
|
#include "LoopThread.h"
|
2015-10-17 03:08:56 +02:00
|
|
|
#include "../logging/logging.h"
|
2015-10-28 15:00:24 +01:00
|
|
|
#include "LoopThreadForkHandler.h"
|
2015-10-17 03:08:56 +02:00
|
|
|
|
|
|
|
using namespace cpputils::logging;
|
2015-10-28 15:00:24 +01:00
|
|
|
using std::function;
|
2015-10-16 02:46:17 +02:00
|
|
|
|
|
|
|
namespace cpputils {
|
|
|
|
|
2015-10-28 15:00:24 +01:00
|
|
|
LoopThread::LoopThread(function<void()> loopIteration): _thread(), _loopIteration(loopIteration) {
|
|
|
|
LoopThreadForkHandler::singleton().add(this);
|
|
|
|
}
|
2015-10-16 02:46:17 +02:00
|
|
|
|
|
|
|
LoopThread::~LoopThread() {
|
2015-10-28 15:00:24 +01:00
|
|
|
LoopThreadForkHandler::singleton().remove(this);
|
2015-10-16 02:46:17 +02:00
|
|
|
stop();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LoopThread::start() {
|
|
|
|
_thread = boost::thread(std::bind(&LoopThread::main, this));
|
|
|
|
}
|
|
|
|
|
|
|
|
void LoopThread::stop() {
|
2015-10-28 15:00:24 +01:00
|
|
|
asyncStop();
|
|
|
|
waitUntilStopped();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LoopThread::asyncStop() {
|
2015-10-16 02:46:17 +02:00
|
|
|
_thread.interrupt();
|
2015-10-28 15:00:24 +01:00
|
|
|
}
|
|
|
|
void LoopThread::waitUntilStopped() {
|
2015-10-16 02:46:17 +02:00
|
|
|
_thread.join();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LoopThread::main() {
|
|
|
|
try {
|
|
|
|
while(true) {
|
2015-10-28 15:00:24 +01:00
|
|
|
_loopIteration();
|
2015-10-16 02:46:17 +02:00
|
|
|
}
|
|
|
|
} catch (const boost::thread_interrupted &e) {
|
|
|
|
//Do nothing, exit thread.
|
|
|
|
} catch (const std::exception &e) {
|
|
|
|
//TODO Think about logging
|
2015-10-17 03:08:56 +02:00
|
|
|
LOG(ERROR) << "LoopThread crashed: " << e.what();
|
2015-10-16 02:46:17 +02:00
|
|
|
} catch (...) {
|
|
|
|
//TODO Think about logging
|
2015-10-17 03:08:56 +02:00
|
|
|
LOG(ERROR) << "LoopThread crashed";
|
2015-10-16 02:46:17 +02:00
|
|
|
}
|
|
|
|
}
|
2015-10-28 15:00:24 +01:00
|
|
|
}
|