#include "pch.h" #include "Patches.h" #include "Hooks/StandardOut.h" HANDLE outputHandle; void InitializeOutput() { AllocConsole(); freopen_s((FILE**)stdout, "CONOUT$", "w", stdout); outputHandle = CreateFileA("CONOUT$", GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); SetStdHandle(STD_OUTPUT_HANDLE, outputHandle); printf("Tadah.DLL v1.0.0\n"); #ifdef _DEBUG SetConsoleTextAttribute(outputHandle, FOREGROUND_RED | FOREGROUND_GREEN); printf("Compiled as Debug\n\n"); #endif } StandardOut__print_t StandardOut__print = (StandardOut__print_t)ADDRESS_STANDARDOUT__PRINT; void __fastcall StandardOut__print_hook(int _this, void*, int type, std::string* message) { StandardOut__print(_this, type, message); #ifndef _DEBUG // Message pointer is offset 4 bytes when the DLL is compiled as release. message = reinterpret_cast((int)message + 4); #endif switch (type) { case RBX__MESSAGE_OUTPUT: SetConsoleTextAttribute(outputHandle, FOREGROUND_BLUE | FOREGROUND_INTENSITY); break; case RBX__MESSAGE_INFO: SetConsoleTextAttribute(outputHandle, FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE); break; case RBX__MESSAGE_WARNING: SetConsoleTextAttribute(outputHandle, FOREGROUND_RED | FOREGROUND_GREEN); break; case RBX__MESSAGE_ERROR: SetConsoleTextAttribute(outputHandle, FOREGROUND_RED | FOREGROUND_INTENSITY); break; } printf("%s\n", message->c_str()); SetConsoleTextAttribute(outputHandle, FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE); }