Change vector to list to allow to remove signal.
[apps/agl-service-can-low-level.git] / low-can-binding / utils / signals.hpp
index 84e81d0..b28942e 100644 (file)
@@ -17,6 +17,7 @@
 
 #pragma once
 
+#include <list>
 #include <vector>
 #include <string>
 #include <fnmatch.h>
@@ -32,8 +33,8 @@ namespace utils
 {
        struct signals_found
        {
-               std::vector<std::shared_ptr<signal_t> > signals;
-               std::vector<std::shared_ptr<diagnostic_message_t> > diagnostic_messages;
+               std::list<std::shared_ptr<signal_t> > signals;
+               std::list<std::shared_ptr<diagnostic_message_t> > diagnostic_messages;
        };
 
        /// @brief Signal manager singleton hold subscription object with attached afb_event_t and its mutex
@@ -59,7 +60,7 @@ namespace utils
                void find_signals(const openxc_DynamicField &key, std::vector<std::shared_ptr<signal_t> >& found_signals);
 
                template <typename T>
-               void lookup_signals_by_name(const std::string& key, std::vector<std::shared_ptr<T> > signals, std::vector<std::shared_ptr<T> >& found_signals)
+               void lookup_signals_by_name(const std::string& key, std::vector<std::shared_ptr<T> > signals, std::list<std::shared_ptr<T> >& found_signals)
                {
                        for(std::shared_ptr<T> s : signals)
                        {
@@ -71,7 +72,7 @@ namespace utils
                }
 
                template <typename T>
-               void lookup_signals_by_id(const double key, std::vector<std::shared_ptr<T> > signals, std::vector<std::shared_ptr<T> >& found_signals)
+               void lookup_signals_by_id(const double key, std::vector<std::shared_ptr<T> > signals, std::list<std::shared_ptr<T> >& found_signals)
                {
                        for(std::shared_ptr<T> s : signals)
                        {