comparison foosdk/sdk/foobar2000/helpers/input_logging.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
4 class input_logging : public input_stubs {
5 public:
6 input_logging() {
7 set_logger(nullptr);
8 }
9
10 event_logger_recorder::ptr log_record( std::function<void () > f ) {
11 auto rec = event_logger_recorder::create();
12 {
13 pfc::vartoggle_t< event_logger::ptr > toggle( m_logger, rec );
14 f();
15 }
16 return rec;
17 }
18
19 void set_logger( event_logger::ptr logger ) {
20 if ( logger.is_valid() ) {
21 m_haveCustomLogger = true;
22 m_logger = logger;
23 } else {
24 m_haveCustomLogger = false;
25 m_logger = new service_impl_t<event_logger_fallback>();
26 }
27 }
28 protected:
29 event_logger::ptr m_logger;
30 bool m_haveCustomLogger = false;
31 };
32
33 #define FB2K_INPUT_LOG_STATUS(X) FB2K_LOG_STATUS(m_logger, X)
34 #define FB2K_INPUT_LOG_WARNING(X) FB2K_LOG_WARNING(m_logger, X)
35 #define FB2K_INPUT_LOG_ERROR(X) FB2K_LOG_ERROR(m_logger, X)