Mercurial > foo_out_sdl
diff foosdk/sdk/foobar2000/SDK/event_logger.h @ 1:20d02a178406 default tip
*: check in everything else
yay
| author | Paper <paper@tflc.us> |
|---|---|
| date | Mon, 05 Jan 2026 02:15:46 -0500 |
| parents | |
| children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/foosdk/sdk/foobar2000/SDK/event_logger.h Mon Jan 05 02:15:46 2026 -0500 @@ -0,0 +1,50 @@ +#pragma once + +#if defined(FOOBAR2000_DESKTOP) || PFC_DEBUG +// RATIONALE +// Mobile target doesn't really care about event logging, logger interface exists there only for source compat +// We can use macros to suppress all PFC_string_formatter bloat for targets that do not care about any of this +#define FB2K_HAVE_EVENT_LOGGER +#endif + +class NOVTABLE event_logger : public service_base { + FB2K_MAKE_SERVICE_INTERFACE(event_logger, service_base); +public: + enum { + severity_status, + severity_warning, + severity_error + }; + void log_status(const char * line) {log_entry(line, severity_status);} + void log_warning(const char * line) {log_entry(line, severity_warning);} + void log_error(const char * line) {log_entry(line, severity_error);} + + virtual void log_entry(const char * line, unsigned severity) = 0; +}; + +class event_logger_fallback : public event_logger { +public: + void log_entry(const char * line, unsigned) {console::print(line);} +}; + +class NOVTABLE event_logger_recorder : public event_logger { + FB2K_MAKE_SERVICE_INTERFACE( event_logger_recorder , event_logger ); +public: + virtual void playback( event_logger::ptr playTo ) = 0; + + static event_logger_recorder::ptr create(); +}; + +#ifdef FB2K_HAVE_EVENT_LOGGER + +#define FB2K_LOG_STATUS(X,Y) (X)->log_status(Y) +#define FB2K_LOG_WARNING(X,Y) (X)->log_warning(Y) +#define FB2K_LOG_ERROR(X,Y) (X)->log_error(Y) + +#else + +#define FB2K_LOG_STATUS(X,Y) ((void)0) +#define FB2K_LOG_WARNING(X,Y) ((void)0) +#define FB2K_LOG_ERROR(X,Y) ((void)0) + +#endif
