summaryrefslogtreecommitdiffstats
path: root/can-config-generator/src/openxc/can_message.hpp
diff options
context:
space:
mode:
authorRomain Forlot <romain.forlot@iot.bzh>2017-04-11 15:49:47 +0200
committerRomain Forlot <romain.forlot@iot.bzh>2017-04-11 15:49:47 +0200
commita58d40b5ae336a54408201963b065ee049b43acd (patch)
tree9769e3d5b624e0238fe550df601e5382f259c52e /can-config-generator/src/openxc/can_message.hpp
parent9e444ade872bc436cf12bc12d03c3a5d51ac0b9e (diff)
parentb7591d16c2686214d5d8dcc0739a233f15aee5db (diff)
Add 'can-config-generator/' from commit 'b7591d16c2686214d5d8dcc0739a233f15aee5db'
git-subtree-dir: can-config-generator git-subtree-mainline: 9e444ade872bc436cf12bc12d03c3a5d51ac0b9e git-subtree-split: b7591d16c2686214d5d8dcc0739a233f15aee5db
Diffstat (limited to 'can-config-generator/src/openxc/can_message.hpp')
-rwxr-xr-xcan-config-generator/src/openxc/can_message.hpp49
1 files changed, 49 insertions, 0 deletions
diff --git a/can-config-generator/src/openxc/can_message.hpp b/can-config-generator/src/openxc/can_message.hpp
new file mode 100755
index 00000000..3f7b0181
--- /dev/null
+++ b/can-config-generator/src/openxc/can_message.hpp
@@ -0,0 +1,49 @@
+#pragma once
+
+#include <string>
+#include <vector>
+#include <json.hpp>
+
+#include "signal.hpp"
+
+namespace openxc
+{
+ class can_message
+ {
+ private:
+ std::string id_;
+ std::string bus_;
+ bool bit_numbering_inverted_;
+ std::vector<signal> signals_;
+ std::string name_;
+ std::vector<std::string> handlers_;
+ bool enabled_;
+ float max_frequency_;
+ float max_signal_frequency_;
+ bool force_send_changed_;
+ bool force_send_changed_signals_;
+
+ public:
+ std::string id() const;
+ void id(const std::string& id);
+ std::string bus() const;
+ bool bit_numbering_inverted() const;
+ const std::vector<signal>& signals() const;
+ std::string name() const;
+ std::vector<std::string> handlers() const;
+ bool enabled() const;
+ float max_frequency() const;
+ float max_signal_frequency() const;
+ bool force_send_changed() const;
+ bool force_send_changed_signals() const;
+
+ void from_json(const nlohmann::json& j);
+ nlohmann::json to_json() const;
+
+ std::uint32_t get_signals_count() const;
+ };
+
+ void to_json(nlohmann::json& j, const can_message& p);
+ void from_json(const nlohmann::json& j, can_message& p);
+ void from_json(const nlohmann::json& j, can_message& p, const std::string& id);
+}