summaryrefslogtreecommitdiff
path: root/src/cam/event_loop.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/cam/event_loop.cpp')
-rw-r--r--src/cam/event_loop.cpp29
1 files changed, 28 insertions, 1 deletions
diff --git a/src/cam/event_loop.cpp b/src/cam/event_loop.cpp
index 13f2583d..94c5d1d3 100644
--- a/src/cam/event_loop.cpp
+++ b/src/cam/event_loop.cpp
@@ -40,8 +40,10 @@ int EventLoop::exec()
exitCode_ = -1;
exit_.store(false, std::memory_order_release);
- while (!exit_.load(std::memory_order_acquire))
+ while (!exit_.load(std::memory_order_acquire)) {
+ dispatchCalls();
event_base_loop(event_, EVLOOP_NO_EXIT_ON_EMPTY);
+ }
return exitCode_;
}
@@ -57,3 +59,28 @@ void EventLoop::interrupt()
{
event_base_loopbreak(event_);
}
+
+void EventLoop::callLater(const std::function<void()> &func)
+{
+ {
+ std::unique_lock<std::mutex> locker(lock_);
+ calls_.push_back(func);
+ }
+
+ interrupt();
+}
+
+void EventLoop::dispatchCalls()
+{
+ std::unique_lock<std::mutex> locker(lock_);
+
+ for (auto iter = calls_.begin(); iter != calls_.end(); ) {
+ std::function<void()> call = std::move(*iter);
+
+ iter = calls_.erase(iter);
+
+ locker.unlock();
+ call();
+ locker.lock();
+ }
+}