Skip to content

File console_logger.hpp

File List > include > nebula_common > loggers > console_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 <cstdio>
#include <iostream>
#include <memory>
#include <ostream>
#include <string>
#include <utility>

namespace nebula::drivers::loggers
{

class ConsoleLogger : public Logger
{
public:
  explicit ConsoleLogger(std::string name) : name_(std::move(name)) {}

  void debug(const std::string & message) override { print_tagged(std::cout, "DEBUG", message); }
  void info(const std::string & message) override { print_tagged(std::cout, "INFO", message); }
  void warn(const std::string & message) override { print_tagged(std::cerr, "WARN", message); }
  void error(const std::string & message) override { print_tagged(std::cerr, "ERROR", message); }

  std::shared_ptr<Logger> child(const std::string & name) override
  {
    return std::make_shared<ConsoleLogger>(name_ + "." + name);
  }

private:
  std::string name_;

  void print_tagged(std::ostream & os, const std::string & severity, const std::string & message)
  {
    // In multithreaded logging, building the string first (... + ...) and then shifting to the
    // stream will ensure that no other logger outputs between string fragments
    os << ("[" + name_ + "][" + severity + "] " + message) << std::endl;
  }
};

}  // namespace nebula::drivers::loggers