* limitations under the License.
*/
-#include <string>
-#include "can-signals.h"
+#include "can-signals.hpp"
-bool match(const std::string &first, const std::string &second)
-{
+#include <fnmatch.h>
+
+#include "low-can-binding.hpp"
+
+/**
+ * @brief Dumb SIGNALS array. It is composed by CanMessageSet
+ * SIGNALS[MESSAGE_SET_ID][CanSignal]
+ */
+std::vector<std::vector<CanSignal>> SIGNALS {
+ {}// message set: example
+};
+const std::vector<CanSignal> getSignals()
+{
+ return SIGNALS[MESSAGE_SET_ID];
}
-CanSignal* getSignals(std::string name)
+size_t getSignalCount()
{
- int n_signals, i;
- CanSignal ret_signals[];
+ return SIGNALS[MESSAGE_SET_ID].size();
+}
- n_signals = size(SIGNALS);
+std::vector<CanSignal> find_can_signals(openxc_DynamicField& key)
+{
+ std::vector<CanSignal> signals;
- for(i=0; i<=n_signals; i++)
+ switch(key.type)
{
- if(SIGNALS[i].generic_name == name)
- return &SIGNALS[i];
- i++;
+ case openxc_DynamicField_Type::openxc_DynamicField_Type_STRING:
+ for(const CanSignal& s : getSignals())
+ {
+ if(fnmatch(key.string_value, s.genericName, FNM_CASEFOLD) == 0)
+ signals.push_back(s);
+ }
+ break;
+ case openxc_DynamicField_Type::openxc_DynamicField_Type_NUM:
+ for(const CanSignal& s : getSignals())
+ {
+ CanMessageDefinition *msg_def = s.message;
+ if(msg_def->id == key.numeric_value)
+ signals.push_back(s);
+ }
+ break;
+ default:
+ ERROR(binder_interface, "find_can_signals: wrong openxc_DynamicField specified. Use openxc_DynamicField_Type_NUM or openxc_DynamicField_Type_STRING type only.");
+ CanSignal cs;
+ ::memset(&cs, 0, sizeof(CanSignal));
+ signals.push_back(cs);
+ return signals;
+ break;
}
- return 0;
+ return signals;
+}
+
+inline uint32_t get_CanSignal_id(const CanSignal& sig)
+{
+ return sig.message->id;
}
+
+const std::map<std::string, struct afb_event> get_subscribed_signals()
+{
+ return subscribed_signals;
+}
\ No newline at end of file