Files
foobar2000-sdk/foobar2000/SDK/event_logger.h

33 lines
1.0 KiB
C++

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();
};
#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)
#define FB2K_HAVE_EVENT_LOGGER