From eafde4cec4fc026444501ed3a096a12e6eb8fc90 Mon Sep 17 00:00:00 2001 From: Romain Forlot Date: Tue, 30 May 2017 17:00:44 +0200 Subject: Renaming configuration to application It is more accurate to name it application because all its members aren't modifiable at runtime (without talking of last_value_ member and few others). Change-Id: Ica0d33dfd9c26cfdea019c2f41ed07777fb36d39 Signed-off-by: Romain Forlot --- CAN-binder/low-can-binding/binding/application.cpp | 96 ++++++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 CAN-binder/low-can-binding/binding/application.cpp (limited to 'CAN-binder/low-can-binding/binding/application.cpp') diff --git a/CAN-binder/low-can-binding/binding/application.cpp b/CAN-binder/low-can-binding/binding/application.cpp new file mode 100644 index 00000000..b916523e --- /dev/null +++ b/CAN-binder/low-can-binding/binding/application.cpp @@ -0,0 +1,96 @@ +/* + * 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 "application.hpp" + +#include "../utils/signals.hpp" +#include "../utils/openxc-utils.hpp" + +/// @brief Return singleton instance of configuration object. +application_t& application_t::instance() +{ + static application_t config; + return config; +} + +can_bus_t& application_t::get_can_bus_manager() +{ + return can_bus_manager_; +} + +diagnostic_manager_t& application_t::get_diagnostic_manager() +{ + return diagnostic_manager_; +} + +uint8_t application_t::get_active_message_set() const +{ + return active_message_set_; +} + +std::vector > application_t::get_can_message_set() +{ + return can_message_set_; +} + +std::vector > application_t::get_all_can_signals() +{ + return can_message_set_[active_message_set_]->get_all_can_signals(); +} + +std::vector >& application_t::get_diagnostic_messages() +{ + return can_message_set_[active_message_set_]->get_diagnostic_messages(); +} + +std::vector >& application_t::get_can_message_definition() +{ + return can_message_set_[active_message_set_]->get_can_message_definition(); +} + +uint32_t application_t::get_signal_id(diagnostic_message_t& sig) const +{ + return sig.get_pid(); +} + +uint32_t application_t::get_signal_id(can_signal_t& sig) const +{ + return sig.get_message()->get_id(); +} + +void application_t::set_active_message_set(uint8_t id) +{ + active_message_set_ = id; +} + + +std::shared_ptr application_t::get_diagnostic_message(const std::string& message_name) const +{ + struct utils::signals_found found; + found = utils::signals_manager_t::instance().find_signals(build_DynamicField(message_name)); + if(! found.diagnostic_messages.empty()) + return found.diagnostic_messages.front(); + return nullptr; +} + +DiagnosticRequest* application_t::get_request_from_diagnostic_message(const std::string& message_name) const +{ + std::shared_ptr diag_msg = get_diagnostic_message(message_name); + if( diag_msg != nullptr && diag_msg->get_supported()) + return new DiagnosticRequest(diag_msg->build_diagnostic_request()); + return nullptr; +} -- cgit 1.2.3-korg