view 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 source

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