File logger.h¶
File List > endstone > logger.h
Go to the documentation of this file
// Copyright (c) 2023, The Endstone Project. (https://endstone.dev) All Rights Reserved.
//
// 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 <string>
#include <utility>
#include <fmt/format.h>
#include <fmt/std.h>
#include "endstone/util/error.h"
namespace endstone {
class Logger {
public:
enum Level : std::uint8_t {
Trace = 0,
Debug = 1,
Info = 2,
Warning = 3,
Error = 4,
Critical = 5,
Off = 6,
};
Logger() = default;
virtual ~Logger() = default;
virtual void setLevel(Level level) = 0;
[[nodiscard]] virtual bool isEnabledFor(Level level) const = 0;
[[nodiscard]] virtual std::string_view getName() const = 0;
virtual void log(Level level, const std::string &message) const = 0;
template <typename... Args>
void log(Level level, const fmt::format_string<Args...> format, Args &&...args) const
{
try {
log(level, fmt::format(format, std::forward<Args>(args)...));
}
catch (std::exception &e) {
log(Error, e.what());
}
}
void trace(const std::string &message) const
{
log(Trace, message);
}
template <typename... Args>
void trace(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Trace, format, std::forward<Args>(args)...);
}
void debug(const std::string &message) const
{
log(Debug, message);
}
template <typename... Args>
void debug(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Debug, format, std::forward<Args>(args)...);
}
void info(const std::string &message) const
{
log(Info, message);
}
template <typename... Args>
void info(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Info, format, std::forward<Args>(args)...);
}
void warning(const std::string &message) const
{
log(Warning, message);
}
template <typename... Args>
void warning(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Warning, format, std::forward<Args>(args)...);
}
void error(const std::string &message) const
{
log(Error, message);
}
template <typename... Args>
void error(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Error, format, std::forward<Args>(args)...);
}
void error(const endstone::Error &error) const
{
log(Error, error.getMessage());
log(Error, error.getStackTrace());
}
void critical(const std::string &message) const
{
log(Critical, message);
}
template <typename... Args>
void critical(const fmt::format_string<Args...> format, Args &&...args) const
{
log(Critical, format, std::forward<Args>(args)...);
}
};
} // namespace endstone