2018-08-03 13:19:12 +04:00
|
|
|
#ifndef DEBUG_DEBUGGING_H
|
|
|
|
#define DEBUG_DEBUGGING_H
|
|
|
|
|
2022-06-08 23:25:50 +02:00
|
|
|
#include <filesystem>
|
|
|
|
#include <functional>
|
2018-08-03 13:19:12 +04:00
|
|
|
|
2021-12-19 22:49:41 +01:00
|
|
|
#include <components/misc/guarded.hpp>
|
2018-08-03 13:19:12 +04:00
|
|
|
|
|
|
|
#include "debuglog.hpp"
|
|
|
|
|
|
|
|
namespace Debug
|
|
|
|
{
|
|
|
|
// ANSI colors for terminal
|
|
|
|
enum Color
|
|
|
|
{
|
|
|
|
Reset = 0,
|
|
|
|
DarkGray = 90,
|
|
|
|
Red = 91,
|
|
|
|
Yellow = 93
|
|
|
|
};
|
|
|
|
|
2018-12-11 23:58:46 +01:00
|
|
|
#ifdef _WIN32
|
|
|
|
bool attachParentConsole();
|
|
|
|
#endif
|
|
|
|
|
2022-05-08 22:43:30 +02:00
|
|
|
using LogListener = std::function<void(Debug::Level, std::string_view prefix, std::string_view msg)>;
|
|
|
|
void setLogListener(LogListener);
|
2018-08-03 13:19:12 +04:00
|
|
|
}
|
|
|
|
|
2020-12-08 22:23:11 +01:00
|
|
|
// Can be used to print messages without timestamps
|
|
|
|
std::ostream& getRawStdout();
|
|
|
|
|
2021-12-19 22:49:41 +01:00
|
|
|
std::ostream& getRawStderr();
|
|
|
|
|
|
|
|
Misc::Locked<std::ostream&> getLockedRawStderr();
|
|
|
|
|
2022-01-13 00:20:16 +01:00
|
|
|
void setupLogging(const std::string& logDir, const std::string& appName, std::ios_base::openmode = std::ios::out);
|
|
|
|
|
|
|
|
int wrapApplication(int (*innerApplication)(int argc, char *argv[]), int argc, char *argv[],
|
|
|
|
const std::string& appName, bool autoSetupLogging = true);
|
2018-08-03 13:19:12 +04:00
|
|
|
|
|
|
|
#endif
|