8#include <boost/log/common.hpp>
9#include <boost/log/sinks.hpp>
11using text_sink = boost::log::sinks::asynchronous_sink<boost::log::sinks::text_ostream_backend>;
13extern boost::log::sources::severity_logger<int> verbose;
14extern boost::log::sources::severity_logger<int> debug;
15extern boost::log::sources::severity_logger<int> info;
16extern boost::log::sources::severity_logger<int> warning;
17extern boost::log::sources::severity_logger<int> error;
18extern boost::log::sources::severity_logger<int> fatal;
20extern boost::log::sources::severity_logger<int> tests;
46 void formatter(
const boost::log::record_view &view, boost::log::formatting_ostream &os);
57 [[nodiscard]] std::unique_ptr<deinit_t>
init(
int min_log_level,
const std::string &log_file);
104 min_max_avg_periodic_logger(boost::log::sources::severity_logger<int> &severity, std::string_view message, std::string_view units, std::chrono::seconds interval_in_seconds = std::chrono::seconds(20)):
108 interval(interval_in_seconds),
109 enabled(config::sunshine.min_log_level <= severity.default_severity()) {
112 void collect_and_log(
const T &value) {
114 auto print_info = [&](
const T &min_value,
const T &max_value,
double avg_value) {
115 auto f = stat_trackers::two_digits_after_decimal();
116 if constexpr (std::is_floating_point_v<T>) {
117 BOOST_LOG(severity.get()) << message <<
" (min/max/avg): " << f % min_value << units <<
"/" << f % max_value << units <<
"/" << f % avg_value << units;
119 BOOST_LOG(severity.get()) << message <<
" (min/max/avg): " << min_value << units <<
"/" << max_value << units <<
"/" << f % avg_value << units;
122 tracker.collect_and_callback_on_interval(value, print_info, interval);
126 void collect_and_log(std::function<T()> func) {
128 collect_and_log(func());
138 bool is_enabled()
const {
143 std::reference_wrapper<boost::log::sources::severity_logger<int>> severity;
146 std::chrono::seconds interval;
168 time_delta_periodic_logger(boost::log::sources::severity_logger<int> &severity, std::string_view message, std::chrono::seconds interval_in_seconds = std::chrono::seconds(20)):
169 logger(severity, message,
"ms", interval_in_seconds) {
172 void first_point(
const std::chrono::steady_clock::time_point &point) {
173 if (logger.is_enabled()) {
178 void first_point_now() {
179 if (logger.is_enabled()) {
180 first_point(std::chrono::steady_clock::now());
184 void second_point_and_log(
const std::chrono::steady_clock::time_point &point) {
185 if (logger.is_enabled()) {
186 logger.collect_and_log(std::chrono::duration<double, std::milli>(point - point1).count());
190 void second_point_now_and_log() {
191 if (logger.is_enabled()) {
192 second_point_and_log(std::chrono::steady_clock::now());
197 if (logger.is_enabled()) {
202 bool is_enabled()
const {
203 return logger.is_enabled();
207 std::chrono::steady_clock::time_point point1 = std::chrono::steady_clock::now();
216 std::string
bracket(
const std::string &input);
223 std::wstring
bracket(
const std::wstring &input);
~deinit_t()
A destructor that restores the initial state.
Definition logging.cpp:46
A helper class for tracking and logging numerical values across a period of time.
Definition logging.h:102
A helper class for tracking and logging short time intervals across a period of time.
Definition logging.h:166
Definition stat_trackers.h:22
Declarations for the configuration of Sunshine.
Handles the initialization and deinitialization of the logging system.
Definition logging.cpp:45
void deinit()
Deinitialize the logging system.
Definition logging.cpp:50
void setup_av_logging(int min_log_level)
Setup AV logging.
Definition logging.cpp:128
std::string bracket(const std::string &input)
Enclose string in square brackets.
Definition logging.cpp:212
void print_help(const char *name)
Print help to stdout.
Definition logging.cpp:192
std::unique_ptr< deinit_t > init(int min_log_level, const std::string &log_file)
Initialize the logging system.
Definition logging.cpp:101
void setup_libdisplaydevice_logging(int min_log_level)
Setup logging for libdisplaydevice.
Definition logging.cpp:156
void log_flush()
Flush the log.
Definition logging.cpp:186
Declarations for streaming statistic tracking.