Skip to content

File rclcpp_logger.hpp

File List > common > rclcpp_logger.hpp

Go to the documentation of this file

// Copyright 2024 TIER IV, Inc.
//
// 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.

#pragma once

#include <nebula_common/loggers/logger.hpp>
#include <rclcpp/logger.hpp>
#include <rclcpp/logging.hpp>

#include <memory>
#include <string>

namespace nebula::drivers::loggers
{

class RclcppLogger : public Logger
{
public:
  explicit RclcppLogger(const std::string & name) : underlying_logger_(rclcpp::get_logger(name)) {}
  explicit RclcppLogger(const rclcpp::Logger & underlying) : underlying_logger_(underlying) {}

  void debug(const std::string & message) override
  {
    RCLCPP_DEBUG_STREAM(underlying_logger_, message);
  }
  void info(const std::string & message) override
  {
    RCLCPP_INFO_STREAM(underlying_logger_, message);
  }
  void warn(const std::string & message) override
  {
    RCLCPP_WARN_STREAM(underlying_logger_, message);
  }
  void error(const std::string & message) override
  {
    RCLCPP_ERROR_STREAM(underlying_logger_, message);
  }

  std::shared_ptr<Logger> child(const std::string & name) override
  {
    return std::make_shared<RclcppLogger>(underlying_logger_.get_child(name));
  }

private:
  rclcpp::Logger underlying_logger_;
};

}  // namespace nebula::drivers::loggers