8 #include <px4_ros2/common/context.hpp>
9 #include <px4_ros2/common/exception.hpp>
11 using namespace std::chrono_literals;
22 template<
typename RosMessageType>
25 using UpdateCallback = std::function<void (
const RosMessageType &)>;
29 : _node(context.node())
31 const std::string namespaced_topic = context.topicNamespacePrefix() + topic;
32 _subscription = _node.create_subscription<RosMessageType>(
33 namespaced_topic, rclcpp::QoS(1).best_effort(),
34 [
this](
const typename RosMessageType::UniquePtr msg) {
36 _last_message_time = _node.get_clock()->now();
37 for (
const auto & callback : _callbacks) {
50 _callbacks.push_back(callback);
59 const RosMessageType &
last()
const
61 if (!hasReceivedMessages()) {
74 return _last_message_time;
84 template<
typename DurationT = std::milli>
85 bool lastValid(
const std::chrono::duration<int64_t, DurationT> max_delay = 500ms)
const
87 return hasReceivedMessages() && _node.get_clock()->now() - _last_message_time < max_delay;
94 typename rclcpp::Subscription<RosMessageType>::SharedPtr _subscription{
nullptr};
97 rclcpp::Time _last_message_time;
99 std::vector<std::function<void(
const RosMessageType &)>> _callbacks{};
101 bool hasReceivedMessages()
const
103 return _last_message_time.seconds() != 0;
Definition: context.hpp:20
Definition: exception.hpp:16
Provides a subscription to arbitrary ROS topics.
Definition: subscription.hpp:24
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:85
void onUpdate(const UpdateCallback &callback)
Add a callback to execute when receiving a new message.
Definition: subscription.hpp:48
const RosMessageType & last() const
Get the last-received message.
Definition: subscription.hpp:59
const rclcpp::Time & lastTime() const
Get the receive-time of the last message.
Definition: subscription.hpp:72