|
1
|
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)
|