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