Cleaned up Util functions

This commit is contained in:
Pasha Bibko
2025-07-20 21:04:24 +01:00
parent cc0300b66c
commit 6a0d2fc0a2
3 changed files with 107 additions and 103 deletions

View File

@@ -6,18 +6,32 @@
#include <cstdlib>
#include <ostream>
namespace LXC::Internal
namespace LXC::Util
{
// Returns a reference to the log file //
// To be used only by LXC components //
inline std::ofstream& Log()
// Enum to translate to the Win32 code for the colors //
enum Color : WORD
{
static std::ofstream sLog;
return sLog;
}
DEFAULT = 0x07,
BLACK = 0x00,
BLUE = 0x01,
GREEN = 0x02,
AQUA = 0x03,
RED = 0x04,
PURPLE = 0x05,
YELLOW = 0x06,
LIGHT_GRAY = 0x07,
LIGHT_BLUE = 0x09,
LIGHT_GREEN = 0x0a,
LIGHT_AQUA = 0x0b,
LIGHT_RED = 0x0c,
LIGHT_PURPLE = 0x0d,
LIGHT_YELLOW = 0x0e,
WHITE = 0x0f
};
}
namespace LXC::Util
namespace LXC::Internal
{
// Checks if a type can be outputted to std::ostream //
template<typename T> concept Logable = requires(std::ostream& os, T t)
@@ -36,57 +50,81 @@ namespace LXC::Util
{ obj.LogStr() } -> std::same_as<std::string>;
};
// Enum to translate to the Win32 code for the colors //
enum Color : WORD
// Returns a reference to the log file //
inline std::ofstream& Log()
{
BLACK = 0x00,
BLUE = 0x01,
GREEN = 0x02,
AQUA = 0x03,
RED = 0x04,
PURPLE = 0x05,
YELLOW = 0x06,
LIGHT_GRAY = 0x07,
LIGHT_BLUE = 0x09,
LIGHT_GREEN = 0x0a,
LIGHT_AQUA = 0x0b,
LIGHT_RED = 0x0c,
LIGHT_PURPLE = 0x0d,
LIGHT_YELLOW = 0x0e,
WHITE = 0x0f
};
static std::ofstream sLog;
return sLog;
}
// Base function for all derived Print() functions //
template<Util::Color col, bool newLine, typename... Args>
inline void WriteImpl(std::ostream& os, Args&&... args)
{
static HANDLE hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
if constexpr(col != Util::Color::DEFAULT)
SetConsoleTextAttribute(hConsole, static_cast<WORD>(col));
(os << ... << std::forward<Args>(args));
if constexpr (newLine)
os << std::endl;
if constexpr (col != Util::Color::DEFAULT)
SetConsoleTextAttribute(hConsole, static_cast<WORD>(Util::Color::DEFAULT));
}
}
namespace LXC::Util
{
// Prints arguments to the console with the given color //
template<Color col, typename... Args>
requires AllLogable<Args...>
inline void PrintAs(Args... args)
requires Internal::AllLogable<Args...>
inline void PrintAs(Args&&... args)
{
// Permenant handle to the console //
static HANDLE hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
// Prints it to the console and resets the color //
SetConsoleTextAttribute(hConsole, (WORD)col);
(std::cout << ... << args);
SetConsoleTextAttribute(hConsole, (WORD)Color::LIGHT_GRAY);
Internal::WriteImpl<col, false>(std::cout, std::forward<Args>(args)...);
}
// Prints arguments to the console //
template<typename... Args>
requires AllLogable<Args...>
inline void Print(Args... args)
requires Internal::AllLogable<Args...>
inline void Print(Args&&... args)
{
// Fowards the arguments to the console //
(std::cout << ... << args);
Internal::WriteImpl<Util::Color::DEFAULT, false>(std::cout, std::forward<Args>(args)...);
}
// Prints arguments to the console with a new-line character at the end //
template<typename... Args>
requires AllLogable<Args...>
inline void PrintLn(Args... args)
requires Internal::AllLogable<Args...>
inline void PrintLn(Args&&... args)
{
// Fowards the arguments to the console //
(std::cout << ... << args);
std::cout << std::endl;
Internal::WriteImpl<Util::Color::DEFAULT, true>(std::cout, std::forward<Args>(args)...);
}
// Logs all the arguments to the file (automatically flushes) //
template<typename... Args>
requires Internal::AllLogable<Args...> && (sizeof...(Args) > 1)
inline void Log(Args&&... args)
{
std::ofstream& log = Internal::Log();
if (log.is_open()) _UNLIKELY
Internal::WriteImpl<Util::Color::DEFAULT, true>(log, R"([LXC] ")", std::forward<Args>(args)..., '"');
}
// Logs a singular argument to the log, calls Log() if it can on the object //
template<typename T>
requires Internal::HasLogStrFunc<T> || Internal::Logable<T>
inline void Log(T arg)
{
std::ofstream& log = Internal::Log();
if (log.is_open()) _UNLIKELY
{
if constexpr (Internal::HasLogStrFunc<T>)
Internal::WriteImpl<Util::Color::DEFAULT, true>(log, "[LXC] ", '{', arg.LogStr(), '}');
else
Internal::WriteImpl<Util::Color::DEFAULT, true>(log, "[LXC] ", '"', arg, '"');
}
}
// Intitalises the log with the given file name //
@@ -103,55 +141,4 @@ namespace LXC::Util
log.close();
});
}
// Logs all the arguments to the file (automatically flushes) //
template<typename... Args>
requires AllLogable<Args...> && (sizeof...(Args) > 1)
inline void Log(Args... args)
{
std::ofstream& log = Internal::Log();
// Only attempts to write to an open log //
if (log.is_open()) _UNLIKELY
{
// Opening symbol to make the log look fancy //
log << "[LXC] \"";
// Fowards the arguments to the log and flushes //
(log << ... << args);
log << "\"\n";
log.flush();
}
}
// Logs a singular argument to the log, calls Log() if it can on the object //
template<typename T>
requires HasLogStrFunc<T> || Logable<T>
inline void Log(T arg)
{
std::ofstream& log = Internal::Log();
// Only attempts to write to an open log //
if (log.is_open()) _UNLIKELY
{
// Opening symbol to make log look fancy //
log << "[LXC] ";
// Logic if it can call LogStr() //
if constexpr (HasLogStrFunc<T>)
{
// Prints the generated string //
log << '{' << arg.LogStr() << "}\n";
log.flush();
}
// Default logic //
else
{
// Prints the singular arg //
log << '"' << arg << "\"\n";
log.flush();
}
}
}
}