Mercurial > foo_out_sdl
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) |
