8#include <px4_ros2/common/context.hpp>
9#include <px4_ros2/common/exception.hpp>
10#include <px4_ros2/components/shared_subscription.hpp>
12using namespace std::chrono_literals;
26template <
typename RosMessageType>
28 using UpdateCallback = std::function<void(
const RosMessageType&)>;
33 const std::string namespaced_topic = context.topicNamespacePrefix() + topic;
35 _node, namespaced_topic, [
this](
const typename RosMessageType::UniquePtr& msg) {
37 _last_message_time = _node.get_clock()->now();
38 for (
const auto& callback : _callbacks) {
49 void onUpdate(
const UpdateCallback& callback) { _callbacks.push_back(callback); }
57 const RosMessageType&
last()
const
59 if (!hasReceivedMessages()) {
70 const rclcpp::Time&
lastTime()
const {
return _last_message_time; }
79 template <
typename DurationT = std::milli>
80 bool lastValid(
const std::chrono::duration<int64_t, DurationT> max_delay = 500ms)
const
82 return hasReceivedMessages() && _node.get_clock()->now() - _last_message_time < max_delay;
89 SharedSubscriptionCallbackInstance _callback_instance;
92 rclcpp::Time _last_message_time;
94 std::vector<std::function<void(
const RosMessageType&)>> _callbacks{};
96 bool hasReceivedMessages()
const {
return _last_message_time.seconds() != 0; }
Shared class for a ROS subscription.
Definition shared_subscription.hpp:39
Definition context.hpp:18
Definition exception.hpp:14
Provides a subscription to arbitrary ROS topics.
Definition subscription.hpp:27
const rclcpp::Time & lastTime() const
Get the receive-time of the last message.
Definition subscription.hpp:70
bool lastValid(const std::chrono::duration< int64_t, DurationT > max_delay=500ms) const
Check whether the last message is still valid. To be valid, the message must have been received withi...
Definition subscription.hpp:80
void onUpdate(const UpdateCallback &callback)
Add a callback to execute when receiving a new message.
Definition subscription.hpp:49
const RosMessageType & last() const
Get the last-received message.
Definition subscription.hpp:57