/* * Copyright (C) 2015, 2016 "IoT.bzh" * Author "Romain Forlot" * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include "can-signals.h" /* Can signal event map making access to afb_event * external to openxc existing structure. */ std::map subscribed_signals; std::map ::iterator subscribed_signals_i; /* Find one or many signals based on its name or id * passed through openxc_DynamicField. */ #define MESSAGE_SET_ID 0 std::vector find_can_signals(openxc_DynamicField &key) { std::vector signals; int n_signals, i; n_signals = getSignalCount(); switch(key->type): { case openxc_DynamicField_Type::openxc_DynamicField_Type_STRING: for(const CanSignal& s : SIGNALS[MESSAGE_SET_ID]) { if(fnmatch(key->string_value, s.genericName) == 0) signals.push_back(s); } break; case openxc_DynamicField_Type::openxc_DynamicField_Type_NUM: for(const CanSignal& s : SIGNALS[MESSAGE_SET_ID]) { CanMessageDefinition *msg_def = s.message; if(msg_def->id == key->numeric_value) signals.push_back(s) } break; default: ERROR(interface, "find_can_signals: wrong openxc_DynamicField specified. Use openxc_DynamicField_Type_NUM or openxc_DynamicField_Type_STRING type only."); return NULL; break; } return signals; } std::vector& getSignals() { return SIGNALS[MESSAGE_SET_ID]; } int getSignalCount() { return SIGNALS[MESSAGE_SET_ID].size(); }