Hyprland/src/debug/Log.hpp

70 lines
2.2 KiB
C++
Raw Normal View History

2022-03-16 20:50:55 +01:00
#pragma once
#include <string>
2023-09-06 12:51:36 +02:00
#include <format>
#include <iostream>
#include <fstream>
#include <chrono>
#include "../includes.hpp"
2023-09-06 12:51:36 +02:00
#include "../helpers/MiscFunctions.hpp"
2022-03-16 20:50:55 +01:00
#define LOGMESSAGESIZE 1024
#define ROLLING_LOG_SIZE 4096
2022-03-16 20:50:55 +01:00
enum LogLevel {
2022-03-16 20:50:55 +01:00
NONE = -1,
LOG = 0,
2022-03-16 20:50:55 +01:00
WARN,
ERR,
2022-06-25 20:50:29 +02:00
CRIT,
INFO,
TRACE
2022-03-16 20:50:55 +01:00
};
namespace Debug {
inline std::string logFile;
inline int64_t* const* disableLogs = nullptr;
inline int64_t* const* disableTime = nullptr;
inline bool disableStdout = false;
inline bool trace = false;
inline bool shuttingDown = false;
2023-09-06 12:51:36 +02:00
inline std::string rollingLog = ""; // rolling log contains the ROLLING_LOG_SIZE tail of the log
void init(const std::string& IS);
2024-04-22 19:44:25 +02:00
//
void log(LogLevel level, std::string str);
2023-09-06 12:51:36 +02:00
template <typename... Args>
void log(LogLevel level, std::format_string<Args...> fmt, Args&&... args) {
2023-09-06 12:51:36 +02:00
if (level == TRACE && !trace)
return;
if (shuttingDown)
return;
2023-09-06 12:51:36 +02:00
std::string logMsg = "";
// print date and time to the ofs
if (disableTime && !**disableTime) {
2023-09-06 12:51:36 +02:00
#ifndef _LIBCPP_VERSION
logMsg += std::format("[{:%T}] ", std::chrono::hh_mm_ss{std::chrono::system_clock::now() - std::chrono::floor<std::chrono::days>(std::chrono::system_clock::now())});
#else
auto c = std::chrono::hh_mm_ss{std::chrono::system_clock::now() - std::chrono::floor<std::chrono::days>(std::chrono::system_clock::now())};
logMsg += std::format("{:%H}:{:%M}:{:%S}", c.hours(), c.minutes(), c.subseconds());
#endif
}
// no need for try {} catch {} because std::format_string<Args...> ensures that vformat never throw std::format_error
// because
// 1. any faulty format specifier that sucks will cause a compilation error.
// 2. and `std::bad_alloc` is catastrophic, (Almost any operation in stdlib could throw this.)
// 3. this is actually what std::format in stdlib does
logMsg += std::vformat(fmt.get(), std::make_format_args(args...));
2023-09-06 12:51:36 +02:00
2024-04-22 19:44:25 +02:00
log(level, logMsg);
2023-09-06 12:51:36 +02:00
}
void wlrLog(wlr_log_importance level, const char* fmt, va_list args);
};