annotate 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
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
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4 class input_logging : public input_stubs {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6 input_logging() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 set_logger(nullptr);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8 }
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 event_logger_recorder::ptr log_record( std::function<void () > f ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 auto rec = event_logger_recorder::create();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13 pfc::vartoggle_t< event_logger::ptr > toggle( m_logger, rec );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 f();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 return rec;
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
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19 void set_logger( event_logger::ptr logger ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20 if ( logger.is_valid() ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21 m_haveCustomLogger = true;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22 m_logger = logger;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23 } else {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 m_haveCustomLogger = false;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25 m_logger = new service_impl_t<event_logger_fallback>();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28 protected:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
29 event_logger::ptr m_logger;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
30 bool m_haveCustomLogger = false;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 #define FB2K_INPUT_LOG_STATUS(X) FB2K_LOG_STATUS(m_logger, X)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 #define FB2K_INPUT_LOG_WARNING(X) FB2K_LOG_WARNING(m_logger, X)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35 #define FB2K_INPUT_LOG_ERROR(X) FB2K_LOG_ERROR(m_logger, X)