Mercurial > foo_out_sdl
comparison 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 |
comparison
equal
deleted
inserted
replaced
| 0:e9bb126753e7 | 1:20d02a178406 |
|---|---|
| 1 #pragma once | |
| 2 | |
| 3 #if defined(FOOBAR2000_DESKTOP) || PFC_DEBUG | |
| 4 // RATIONALE | |
| 5 // Mobile target doesn't really care about event logging, logger interface exists there only for source compat | |
| 6 // We can use macros to suppress all PFC_string_formatter bloat for targets that do not care about any of this | |
| 7 #define FB2K_HAVE_EVENT_LOGGER | |
| 8 #endif | |
| 9 | |
| 10 class NOVTABLE event_logger : public service_base { | |
| 11 FB2K_MAKE_SERVICE_INTERFACE(event_logger, service_base); | |
| 12 public: | |
| 13 enum { | |
| 14 severity_status, | |
| 15 severity_warning, | |
| 16 severity_error | |
| 17 }; | |
| 18 void log_status(const char * line) {log_entry(line, severity_status);} | |
| 19 void log_warning(const char * line) {log_entry(line, severity_warning);} | |
| 20 void log_error(const char * line) {log_entry(line, severity_error);} | |
| 21 | |
| 22 virtual void log_entry(const char * line, unsigned severity) = 0; | |
| 23 }; | |
| 24 | |
| 25 class event_logger_fallback : public event_logger { | |
| 26 public: | |
| 27 void log_entry(const char * line, unsigned) {console::print(line);} | |
| 28 }; | |
| 29 | |
| 30 class NOVTABLE event_logger_recorder : public event_logger { | |
| 31 FB2K_MAKE_SERVICE_INTERFACE( event_logger_recorder , event_logger ); | |
| 32 public: | |
| 33 virtual void playback( event_logger::ptr playTo ) = 0; | |
| 34 | |
| 35 static event_logger_recorder::ptr create(); | |
| 36 }; | |
| 37 | |
| 38 #ifdef FB2K_HAVE_EVENT_LOGGER | |
| 39 | |
| 40 #define FB2K_LOG_STATUS(X,Y) (X)->log_status(Y) | |
| 41 #define FB2K_LOG_WARNING(X,Y) (X)->log_warning(Y) | |
| 42 #define FB2K_LOG_ERROR(X,Y) (X)->log_error(Y) | |
| 43 | |
| 44 #else | |
| 45 | |
| 46 #define FB2K_LOG_STATUS(X,Y) ((void)0) | |
| 47 #define FB2K_LOG_WARNING(X,Y) ((void)0) | |
| 48 #define FB2K_LOG_ERROR(X,Y) ((void)0) | |
| 49 | |
| 50 #endif |
