Mercurial > foo_out_sdl
diff 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 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/foosdk/sdk/foobar2000/helpers/input_logging.h Mon Jan 05 02:15:46 2026 -0500 @@ -0,0 +1,35 @@ +#pragma once + + +class input_logging : public input_stubs { +public: + input_logging() { + set_logger(nullptr); + } + + event_logger_recorder::ptr log_record( std::function<void () > f ) { + auto rec = event_logger_recorder::create(); + { + pfc::vartoggle_t< event_logger::ptr > toggle( m_logger, rec ); + f(); + } + return rec; + } + + void set_logger( event_logger::ptr logger ) { + if ( logger.is_valid() ) { + m_haveCustomLogger = true; + m_logger = logger; + } else { + m_haveCustomLogger = false; + m_logger = new service_impl_t<event_logger_fallback>(); + } + } +protected: + event_logger::ptr m_logger; + bool m_haveCustomLogger = false; +}; + +#define FB2K_INPUT_LOG_STATUS(X) FB2K_LOG_STATUS(m_logger, X) +#define FB2K_INPUT_LOG_WARNING(X) FB2K_LOG_WARNING(m_logger, X) +#define FB2K_INPUT_LOG_ERROR(X) FB2K_LOG_ERROR(m_logger, X)
