Program Listing for File event_observer.hpp
↰ Return to documentation for file (include/kuka_iiqka_eac_driver/event_observer.hpp
)
// Copyright 2024 Márk Szitanics
//
// 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.
#ifndef KUKA_IIQKA_EAC_DRIVER__EVENT_OBSERVER_HPP_
#define KUKA_IIQKA_EAC_DRIVER__EVENT_OBSERVER_HPP_
#include <string>
#include "rclcpp/macros.hpp"
#include "kuka/external-control-sdk/iiqka/sdk.h"
#include "kuka_drivers_core/hardware_event.hpp"
#include "kuka_iiqka_eac_driver/hardware_interface.hpp"
namespace kuka_eac
{
class KukaEACEventObserver : public kuka::external::control::EventHandler
{
public:
explicit KukaEACEventObserver(KukaEACHardwareInterface * hw_interface)
: hw_interface_(hw_interface)
{
}
void OnSampling() override
{
hw_interface_->set_server_event(kuka_drivers_core::HardwareEvent::CONTROL_STARTED);
RCLCPP_INFO(rclcpp::get_logger("KukaEACHardwareInterface"), "External control is active");
}
void OnControlModeSwitch(const std::string &) override
{
hw_interface_->set_server_event(kuka_drivers_core::HardwareEvent::CONTROL_MODE_SWITCH);
RCLCPP_INFO(
rclcpp::get_logger("KukaEACHardwareInterface"), "Control mode switch is in progress");
hw_interface_->reset_cycle_count();
}
void OnStopped(const std::string &) override
{
hw_interface_->set_server_event(kuka_drivers_core::HardwareEvent::CONTROL_STOPPED);
RCLCPP_INFO(rclcpp::get_logger("KukaEACHardwareInterface"), "External control finished");
hw_interface_->set_stop_flag();
}
void OnError(const std::string & reason) override
{
hw_interface_->set_server_event(kuka_drivers_core::HardwareEvent::ERROR);
RCLCPP_ERROR(
rclcpp::get_logger("KukaEACHardwareInterface"), "External control stopped by an error");
RCLCPP_ERROR(rclcpp::get_logger("KukaEACHardwareInterface"), reason.c_str());
hw_interface_->set_stop_flag();
}
private:
KukaEACHardwareInterface * hw_interface_;
};
} // namespace kuka_eac
#endif // KUKA_IIQKA_EAC_DRIVER__EVENT_OBSERVER_HPP_