Files
MuditaOS/module-sys/Service/Mailbox.hpp
Adam f5f27d642f EGD-2955 EGD-3588 Timers fully refactored & updated (#721)
* Timers now are Application thread safe
* Timers now have consistent API independend of Application (no more c style timers)
* Timers can have either: callback or override onTimer() method - this
  way we can create more complicated timers or just use existing ones
* gui::Timer added via adapter class GuiTimer to decouple sys::Timer
  with gui::Timer
* Fixed race in wrapper
* Updated docs
* fixed using std and cpp_freertos and DataReceivedHandler hidden in Application.hpp
2020-10-02 14:04:57 +02:00

78 lines
1.6 KiB
C++

#pragma once
#include <deque>
#include "thread.hpp"
#include <mutex.hpp>
#include <condition_variable.hpp>
template <typename T> class Mailbox
{
public:
Mailbox(cpp_freertos::Thread *thread) : thread_(thread)
{}
T peek()
{
cpp_freertos::LockGuard mlock(mutex_);
while (queue_.empty()) {
thread_->Wait(cond_, mutex_);
}
auto item = queue_.front();
return item;
}
T pop(uint32_t timeout = portMAX_DELAY)
{
cpp_freertos::LockGuard mlock(mutex_);
while (queue_.empty()) {
if (thread_->Wait(cond_, mutex_, timeout) == false) {
return nullptr;
}
}
auto item = queue_.front();
queue_.pop_front();
return item;
}
void pop(T &item)
{
cpp_freertos::LockGuard mlock(mutex_);
while (queue_.empty()) {
thread_->Wait(cond_, mutex_);
}
item = queue_.front();
queue_.pop_front();
}
void push_front(const T &item)
{
mutex_.Lock();
queue_.push_front(item);
mutex_.Unlock();
}
void push(const T &item)
{
mutex_.Lock();
queue_.push_back(item);
mutex_.Unlock();
cond_.Signal();
}
void push(T &&item)
{
mutex_.Lock();
queue_.push_back(std::move(item));
mutex_.Unlock();
cond_.Signal();
}
private:
cpp_freertos::Thread *thread_;
std::deque<T> queue_;
cpp_freertos::MutexStandard mutex_;
cpp_freertos::ConditionVariable cond_;
};