t8-mod/source/proxy-dll/component/debugging.cpp
2024-11-28 02:58:49 -08:00

109 lines
2.8 KiB
C++

#include <std_include.hpp>
#include "definitions/game.hpp"
#include "component/scheduler.hpp"
#include "component/gsc_custom.hpp"
#include "loader/component_loader.hpp"
#include <utilities/hook.hpp>
#include <utilities/string.hpp>
namespace debugging
{
namespace
{
const char* get_connectivity_info_string(int infoBitmask)
{
char connectionInfoString[64];
for (int bitNumber = 0; bitNumber < 21; bitNumber++)
{
if ((1 << bitNumber) & infoBitmask)
{
connectionInfoString[bitNumber * 2] = (char)(bitNumber + 0x41);
}
else
{
connectionInfoString[bitNumber * 2] = 0x2D;
}
connectionInfoString[(bitNumber * 2) + 1] = 0x2E;
}
connectionInfoString[42] = NULL;
return utilities::string::va("%s", connectionInfoString);
}
void draw_debug_info()
{
int infoBitmask = 0; int requiredMask = 0x1337FA;
game::Live_GetConnectivityInformation(0, &infoBitmask);
bool connected = (requiredMask & infoBitmask) == requiredMask;
void* font = reinterpret_cast<void*>(game::sharedUiInfo->assets.bigFont); if (!font) return;
if (!connected)
{
float color[4] = { 0.8f, 1.0f, 0.3f, 0.8f };
const char* sz = get_connectivity_info_string(infoBitmask);
game::ScreenPlacement* scrPlace = game::ScrPlace_GetView(0);
float offset_x = scrPlace->realViewportSize[0] - 8.0f
- game::UI_TextWidth(0, sz, 0x7FFFFFFF, font, 0.45f);
float offset_y = scrPlace->realViewportSize[1] - 8.0f;
game::R_AddCmdDrawText(sz, 0x7FFFFFFF, font, offset_x, offset_y, 0.45f, 0.45f, 0.0f, color, game::ITEM_TEXTSTYLE_BORDERED);
}
}
void test_key_catcher()
{
static uint32_t last_press_time = 0;
if ((GetAsyncKeyState(VK_HOME) & 0x01)/* && (static_cast<uint32_t>(time(nullptr)) - last_press_time) > 1*/)
{
last_press_time = static_cast<uint32_t>(time(nullptr));
/* ACTION_PLACE_HOLDER */
}
}
}
utilities::hook::detour sys_error_hook;
void sys_error_stub(uint32_t code, const char* message)
{
if (code == gsc_custom::linking_error)
{
gsc_custom::find_linking_issues();
return; // converted to runtime error to avoid the crash
}
const char* error_message = runtime_errors::get_error_message(code);
if (error_message)
{
logger::write(logger::LOG_TYPE_ERROR, "[sys_error] %s (%d): %s", error_message, code, message);
}
else
{
logger::write(logger::LOG_TYPE_ERROR, "[sys_error] %d: %s", code, message);
}
sys_error_hook.invoke<void>(code, message);
}
class component final : public component_interface
{
public:
void post_unpack() override
{
sys_error_hook.create(0x143D36CC0_g, sys_error_stub);
scheduler::loop(draw_debug_info, scheduler::renderer);
scheduler::loop(test_key_catcher, scheduler::main);
}
};
}
REGISTER_COMPONENT(debugging::component)