ros2_tracing/tracetools_test/src/test_timer.cpp

66 lines
1.5 KiB
C++
Raw Normal View History

2019-06-18 09:10:05 +02:00
// Copyright 2019 Robert Bosch GmbH
//
// 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.
2019-06-05 15:35:46 +02:00
#include <memory>
2019-06-03 11:36:16 +02:00
#include <chrono>
#include "rclcpp/rclcpp.hpp"
using namespace std::chrono_literals;
2019-06-19 15:46:44 +02:00
#define NODE_NAME "test_timer"
#define TIMER_PERIOD 1ms
2019-06-03 11:36:16 +02:00
class TimerNode : public rclcpp::Node
{
public:
2019-06-05 15:35:46 +02:00
explicit TimerNode(rclcpp::NodeOptions options)
2019-06-19 15:46:44 +02:00
: Node(NODE_NAME, options)
2019-06-05 15:35:46 +02:00
{
is_done_ = false;
timer_ = this->create_wall_timer(
2019-06-19 15:46:44 +02:00
TIMER_PERIOD,
2019-06-05 15:35:46 +02:00
std::bind(&TimerNode::timer_callback, this));
}
2019-06-03 11:36:16 +02:00
private:
2019-06-05 15:35:46 +02:00
void timer_callback()
{
if (is_done_) {
rclcpp::shutdown();
} else {
is_done_ = true;
2019-06-03 11:36:16 +02:00
}
2019-06-05 15:35:46 +02:00
}
2019-06-03 11:36:16 +02:00
2019-06-05 15:35:46 +02:00
rclcpp::TimerBase::SharedPtr timer_;
bool is_done_;
2019-06-03 11:36:16 +02:00
};
2019-06-05 15:35:46 +02:00
int main(int argc, char * argv[])
2019-06-03 11:36:16 +02:00
{
2019-06-05 15:35:46 +02:00
rclcpp::init(argc, argv);
2019-06-03 11:36:16 +02:00
2019-06-05 15:35:46 +02:00
rclcpp::executors::SingleThreadedExecutor exec;
auto timer_node = std::make_shared<TimerNode>(rclcpp::NodeOptions());
exec.add_node(timer_node);
2019-06-03 11:36:16 +02:00
2019-06-05 15:35:46 +02:00
printf("spinning\n");
exec.spin();
2019-06-03 11:36:16 +02:00
2019-06-05 15:35:46 +02:00
// Will actually be called inside the timer's callback
rclcpp::shutdown();
return 0;
2019-06-03 11:36:16 +02:00
}