From bfb1a566b781e63dfda6038d9918706423410c26 Mon Sep 17 00:00:00 2001 From: Matthew Barth Date: Thu, 5 Oct 2017 17:03:40 -0500 Subject: Add timer event management Events defined to have timers require the ability to find a timer, add a timer to the event, and removing a timer event entirely. These event timers are intended to allow actions based on the event to be delayed or recurring based on the timer defined. Change-Id: Ieaf26f031c5e5aac9472e92354bfb76392642cb4 Signed-off-by: Matthew Barth --- control/zone.hpp | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 72 insertions(+), 1 deletion(-) (limited to 'control/zone.hpp') diff --git a/control/zone.hpp b/control/zone.hpp index 9c08032..1fdeaf2 100644 --- a/control/zone.hpp +++ b/control/zone.hpp @@ -1,6 +1,7 @@ #pragma once #include #include +#include #include #include #include "fan.hpp" @@ -138,6 +139,18 @@ class Zone const std::string& name, const bool hasOwner); + /** + * @brief Get the group's list of service names + * + * @param[in] group - Group to get service names for + * + * @return - The list of service names + */ + inline auto getGroupServices(const Group* group) + { + return _services.at(*group); + } + /** * @brief Initialize a set speed event properties and actions * @@ -263,6 +276,64 @@ class Zone */ void decTimerExpired(); + /** + * @brief Get the event pointer used with this zone's timers + * + * @return - The Dbus event pointer for timers + */ + inline auto& getEventPtr() + { + return _sdEvents; + } + + /** + * @brief Get the list of timer events + * + * @return - List of timer events + */ + inline auto& getTimerEvents() + { + return _timerEvents; + } + + /** + * @brief Find the first instance of a timer event + * + * @param[in] eventGroup - Group associated with a timer + * @param[in] eventActions - List of actions associated with a timer + * + * @return - Iterator to the timer event + */ + std::vector::iterator findTimer( + const Group& eventGroup, + const std::vector& eventActions); + + /** + * @brief Add a timer to the list of timer based events + * + * @param[in] data - Event data for timer + * @param[in] timer - Timer to be added + */ + inline void addTimer( + std::unique_ptr&& data, + std::unique_ptr&& timer) + { + _timerEvents.emplace_back(std::move(data), std::move(timer)); + }; + + /** + * @brief Remove the given timer event + * + * @param[in] teIter - Iterator pointing to the timer event to remove + */ + inline void removeTimer(std::vector::iterator& teIter) + { + assert(teIter != std::end(_timerEvents)); + std::get(*teIter).reset(); + std::get(*teIter).reset(); + _timerEvents.erase(teIter); + } + /** * @brief Callback function for event timers that processes the given * actions for a group @@ -395,7 +466,7 @@ class Zone /** * @brief List of timers for events */ - std::vector> _timerEvents; + std::vector _timerEvents; /** * @brief Get the request speed base if defined, otherwise the -- cgit v1.2.1