aurora/lib/logging.hpp
Luke Street a600b0b84c Rewrite attribute buffer, matrix & stream handling
Now array attributes (GXSetArray) will be properly
fetched based on the vertex format. Buffers are
still assumed to be byte-swapped to little-endian.

Stream handling completely redone and many issues
resolved.

Eliminates matrix transposes. AURORA_NATIVE_MATRIX
is no longer necessary and removed.
2025-04-14 17:17:59 -06:00

56 lines
1.6 KiB
C++

#pragma once
#include <aurora/aurora.h>
#include <fmt/base.h>
#include <fmt/format.h>
#include <cstdlib>
#include <string_view>
namespace aurora {
void log_internal(AuroraLogLevel level, const char* module, const char* message, unsigned int len) noexcept;
struct Module {
const char* name;
explicit Module(const char* name) noexcept : name(name) {}
template <typename... T>
void report(const AuroraLogLevel level, fmt::format_string<T...> fmt, T&&... args) noexcept {
auto message = fmt::format(fmt, std::forward<T>(args)...);
log_internal(level, name, message.c_str(), message.size());
}
template <typename... T>
void debug(fmt::format_string<T...> fmt, T&&... args) noexcept {
report(LOG_DEBUG, fmt, std::forward<T>(args)...);
}
template <typename... T>
void info(fmt::format_string<T...> fmt, T&&... args) noexcept {
report(LOG_INFO, fmt, std::forward<T>(args)...);
}
template <typename... T>
void warn(fmt::format_string<T...> fmt, T&&... args) noexcept {
report(LOG_WARNING, fmt, std::forward<T>(args)...);
}
template <typename... T>
void error(fmt::format_string<T...> fmt, T&&... args) noexcept {
report(LOG_ERROR, fmt, std::forward<T>(args)...);
}
template <typename... T>
[[noreturn]] void fatal(fmt::format_string<T...> fmt, T&&... args) noexcept {
report(LOG_FATAL, fmt, std::forward<T>(args)...);
std::abort();
}
};
} // namespace aurora
template <>
struct fmt::formatter<AuroraLogLevel> : formatter<std::string_view> {
auto format(AuroraLogLevel level, format_context& ctx) const -> format_context::iterator;
};