5#include <SDL3/SDL_log.h>
6#include "SDL3pp_callbackWrapper.h"
7#include "SDL3pp_error.h"
8#include "SDL3pp_strings.h"
84 SDL_LOG_PRIORITY_INVALID;
89 SDL_LOG_PRIORITY_VERBOSE;
100 SDL_LOG_PRIORITY_CRITICAL;
138 : m_category(category)
148 : m_category(SDL_LogCategory(category))
209 SDL_LogMessage(m_category, priority,
"%s", (
const char*)(message));
237 template<
class... ARGS>
239 std::string_view fmt,
266 template<
class... ARGS>
267 void LogTrace(std::string_view fmt, ARGS&&... args)
const;
292 template<
class... ARGS>
293 void LogVerbose(std::string_view fmt, ARGS&&... args)
const;
319 template<
class... ARGS>
320 void LogDebug(std::string_view fmt, ARGS&&... args)
const;
346 template<
class... ARGS>
347 void LogInfo(std::string_view fmt, ARGS&&... args)
const;
373 template<
class... ARGS>
374 void LogWarn(std::string_view fmt, ARGS&&... args)
const;
400 template<
class... ARGS>
401 void LogError(std::string_view fmt, ARGS&&... args)
const;
428 template<
class... ARGS>
429 void LogCritical(std::string_view fmt, ARGS&&... args)
const;
433 SDL_LOG_CATEGORY_APPLICATION;
454 SDL_LOG_CATEGORY_RESERVED2;
457 SDL_LOG_CATEGORY_RESERVED3;
460 SDL_LOG_CATEGORY_RESERVED4;
463 SDL_LOG_CATEGORY_RESERVED5;
466 SDL_LOG_CATEGORY_RESERVED6;
469 SDL_LOG_CATEGORY_RESERVED7;
472 SDL_LOG_CATEGORY_RESERVED8;
475 SDL_LOG_CATEGORY_RESERVED9;
478 SDL_LOG_CATEGORY_RESERVED10;
496 SDL_SetLogPriorities(priority);
515 SDL_SetLogPriority(category, priority);
537 return SDL_GetLogPriority(category);
580 CheckError(SDL_SetLogPriorityPrefix(priority, prefix));
609 SDL_LogMessage(category, priority,
"%s",
static_cast<const char*
>(message));
634 SDL_Log(
"%s",
static_cast<const char*
>(message));
664template<
class... ARGS>
665inline void Log(std::string_view fmt, ARGS&&... args)
693template<
class... ARGS>
696 std::string_view fmt,
700 category, priority, std::vformat(fmt, std::make_format_args(args...)));
703template<
class... ARGS>
705 std::string_view fmt,
734template<
class... ARGS>
740template<
class... ARGS>
767template<
class... ARGS>
769 std::string_view fmt,
775template<
class... ARGS>
803template<
class... ARGS>
809template<
class... ARGS>
837template<
class... ARGS>
843template<
class... ARGS>
871template<
class... ARGS>
874 LogMessage(category, SDL_LOG_PRIORITY_WARN, fmt, args...);
877template<
class... ARGS>
905template<
class... ARGS>
908 LogMessage(category, SDL_LOG_PRIORITY_ERROR, fmt, args...);
911template<
class... ARGS>
939template<
class... ARGS>
941 std::string_view fmt,
944 LogMessage(category, SDL_LOG_PRIORITY_CRITICAL, fmt, args...);
947template<
class... ARGS>
1003 return SDL_GetDefaultLogOutputFunction();
1022 SDL_GetLogOutputFunction(callback, userdata);
1046 if (userdata ==
nullptr) {
1048 cb(
nullptr, c, p, m);
1051 if (
auto cb = Wrapper::at(userdata))
return cb;
1053 cb(userdata, c, p, m);
1074 return SDL_SetLogOutputFunction(callback, userdata);
1096 SDL_SetLogOutputFunction(
1098 void* userdata,
int category,
LogPriority priority,
const char* message) {
1099 return Wrapper::Call(userdata,
LogCategory{category}, priority, message);
1101 Wrapper::Wrap(std::move(callback)));
The predefined log categories.
Definition: SDL3pp_log.h:128
Helpers to use C++ strings parameters.
Definition: SDL3pp_strings.h:43
constexpr void CheckError(bool result)
Check and throw if returned value from SDL is an error.
Definition: SDL3pp_error.h:198
void SetLogPriorities(LogPriority priority)
Set the priority of all log categories.
Definition: SDL3pp_log.h:494
constexpr LogCategory LOG_CATEGORY_ASSERT
ASSERT.
Definition: SDL3pp_log.h:437
constexpr LogCategory LOG_CATEGORY_AUDIO
AUDIO.
Definition: SDL3pp_log.h:441
void LogWarn(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_WARN.
Definition: SDL3pp_log.h:878
constexpr LogCategory LOG_CATEGORY_VIDEO
VIDEO.
Definition: SDL3pp_log.h:443
SDL_LogCategory LogCategoryRaw
Alias to raw representation for LogCategory.
Definition: SDL3pp_log.h:63
constexpr LogCategory LOG_CATEGORY_RESERVED10
RESERVED10.
Definition: SDL3pp_log.h:477
void LogVerbose(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_VERBOSE.
Definition: SDL3pp_log.h:768
void SetLogPriorityPrefix(LogPriority priority, StringParam prefix)
Set the text prepended to log messages of a given priority.
Definition: SDL3pp_log.h:578
LogPriority GetLogPriority(int category)
Get the priority of a particular log category.
Definition: SDL3pp_log.h:535
void SetLogPriority(int category, LogPriority priority)
Set the priority of a particular log category.
Definition: SDL3pp_log.h:513
void LogTrace(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_TRACE.
Definition: SDL3pp_log.h:735
void LogUnformatted(LogPriority priority, StringParam message) const
Log an unformatted message with the specified priority.
Definition: SDL3pp_log.h:207
constexpr LogPriority LOG_PRIORITY_INVALID
INVALID.
Definition: SDL3pp_log.h:83
void SetLogOutputFunction(LogOutputFunction callback, void *userdata)
Replace the default log output function with one of your own.
Definition: SDL3pp_log.h:1071
constexpr LogCategory LOG_CATEGORY_INPUT
INPUT.
Definition: SDL3pp_log.h:447
LogOutputCB GetLogOutputFunction()
Get the current log output function.
Definition: SDL3pp_log.h:1040
constexpr LogCategory LOG_CATEGORY_ERROR
ERROR.
Definition: SDL3pp_log.h:435
void LogInfo(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_INFO.
Definition: SDL3pp_log.h:844
constexpr LogCategory(int category)
Wraps LogCategory.
Definition: SDL3pp_log.h:147
constexpr LogCategory LOG_CATEGORY_RESERVED5
RESERVED5.
Definition: SDL3pp_log.h:462
void LogVerbose(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_VERBOSE.
Definition: SDL3pp_log.h:776
void LogCritical(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_CRITICAL.
Definition: SDL3pp_log.h:940
void LogTrace(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_TRACE.
Definition: SDL3pp_log.h:741
void ResetLogOutputFunction()
Replace the current log output function with the default one.
Definition: SDL3pp_log.h:1114
constexpr LogPriority LOG_PRIORITY_CRITICAL
CRITICAL.
Definition: SDL3pp_log.h:99
void LogCritical(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_CRITICAL.
Definition: SDL3pp_log.h:948
void LogDebug(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_DEBUG.
Definition: SDL3pp_log.h:804
constexpr LogCategory LOG_CATEGORY_RESERVED8
RESERVED8.
Definition: SDL3pp_log.h:471
LogPriority GetLogPriority() const
Get the priority of a particular log category.
Definition: SDL3pp_log.h:540
SDL_LogPriority LogPriority
The predefined log priorities.
Definition: SDL3pp_log.h:81
void LogError(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_ERROR.
Definition: SDL3pp_log.h:912
constexpr LogCategory LOG_CATEGORY_RESERVED7
RESERVED7.
Definition: SDL3pp_log.h:468
constexpr LogPriority LOG_PRIORITY_WARN
WARN.
Definition: SDL3pp_log.h:95
void LogUnformatted(LogCategory category, LogPriority priority, StringParam message)
Log an unformatted message with LOG_CATEGORY_APPLICATION and LOG_PRIORITY_INFO.
Definition: SDL3pp_log.h:605
void LogMessage(LogPriority priority, std::string_view fmt, ARGS... args) const
Log a message with the specified priority.
Definition: SDL3pp_log.h:704
void LogDebug(std::string_view fmt, ARGS &&... args) const
Log a message with LOG_PRIORITY_DEBUG.
Definition: SDL3pp_log.h:810
void LogError(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_ERROR.
Definition: SDL3pp_log.h:906
constexpr LogCategory LOG_CATEGORY_TEST
TEST.
Definition: SDL3pp_log.h:449
constexpr LogCategory LOG_CATEGORY_RESERVED2
RESERVED2.
Definition: SDL3pp_log.h:453
constexpr LogPriority LOG_PRIORITY_DEBUG
DEBUG.
Definition: SDL3pp_log.h:91
void LogMessage(LogCategory category, LogPriority priority, std::string_view fmt, ARGS... args)
Log a message with the specified category and priority.
Definition: SDL3pp_log.h:694
void Log(std::string_view fmt, ARGS &&... args)
Log a message with LOG_CATEGORY_APPLICATION and LOG_PRIORITY_INFO.
Definition: SDL3pp_log.h:665
constexpr LogCategory LOG_CATEGORY_RENDER
RENDER.
Definition: SDL3pp_log.h:445
constexpr LogCategory LOG_CATEGORY_APPLICATION
APPLICATION.
Definition: SDL3pp_log.h:432
constexpr LogCategory LOG_CATEGORY_GPU
GPU.
Definition: SDL3pp_log.h:451
std::function< void(LogCategory, LogPriority, const char *)> LogOutputCB
The prototype for the log output callback function.
Definition: SDL3pp_log.h:987
void LogInfo(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_INFO.
Definition: SDL3pp_log.h:838
constexpr LogCategory LOG_CATEGORY_SYSTEM
SYSTEM.
Definition: SDL3pp_log.h:439
void SetLogPriority(LogPriority priority) const
Set the priority of a particular log category.
Definition: SDL3pp_log.h:518
SDL_LogOutputFunction LogOutputFunction
The prototype for the log output callback function.
Definition: SDL3pp_log.h:968
void ResetLogPriorities()
Reset all priorities to default.
Definition: SDL3pp_log.h:557
constexpr LogPriority LOG_PRIORITY_ERROR
ERROR.
Definition: SDL3pp_log.h:97
constexpr LogPriority LOG_PRIORITY_COUNT
COUNT.
Definition: SDL3pp_log.h:102
void LogWarn(LogCategory category, std::string_view fmt, ARGS &&... args)
Log a message with LOG_PRIORITY_WARN.
Definition: SDL3pp_log.h:872
LogOutputFunction GetDefaultLogOutputFunction()
Get the default log output function.
Definition: SDL3pp_log.h:1001
constexpr LogPriority LOG_PRIORITY_VERBOSE
VERBOSE.
Definition: SDL3pp_log.h:88
constexpr LogPriority LOG_PRIORITY_INFO
INFO.
Definition: SDL3pp_log.h:93
constexpr LogCategory LOG_CATEGORY_RESERVED9
RESERVED9.
Definition: SDL3pp_log.h:474
constexpr LogCategory LOG_CATEGORY_RESERVED4
RESERVED4.
Definition: SDL3pp_log.h:459
constexpr LogPriority LOG_PRIORITY_TRACE
TRACE.
Definition: SDL3pp_log.h:86
constexpr LogCategory LOG_CATEGORY_CUSTOM
CUSTOM.
Definition: SDL3pp_log.h:480
constexpr LogCategory(LogCategoryRaw category=SDL_LOG_CATEGORY_APPLICATION)
Wraps LogCategory.
Definition: SDL3pp_log.h:137
constexpr LogCategory LOG_CATEGORY_RESERVED3
RESERVED3.
Definition: SDL3pp_log.h:456
constexpr LogCategory LOG_CATEGORY_RESERVED6
RESERVED6.
Definition: SDL3pp_log.h:465
Main include header for the SDL3pp library.
Stored Wrapper unique by type result callbacks.
Definition: SDL3pp_callbackWrapper.h:242