From 2459506beb1904fad938c582c94dc2ff4f54f8a5 Mon Sep 17 00:00:00 2001 From: Cleverson Date: Fri, 1 Mar 2024 10:28:55 -0300 Subject: [PATCH] - Fixed cvar pointer registration to prevent crash - Fixed vector calculation - Check path to prevent crash --- AccuracyFix/AccuracyFix.cpp | 35 +++++++++++++++++------------------ AccuracyFix/AccuracyUtil.cpp | 12 ++++++------ 2 files changed, 23 insertions(+), 24 deletions(-) diff --git a/AccuracyFix/AccuracyFix.cpp b/AccuracyFix/AccuracyFix.cpp index af75148..d743de7 100644 --- a/AccuracyFix/AccuracyFix.cpp +++ b/AccuracyFix/AccuracyFix.cpp @@ -26,24 +26,20 @@ void CAccuracyFix::ServerActivate() { if (SlotInfo->weaponName[0u] != '\0') { - std::string cvarName = "af_distance_"; + char cvarName[64] = { 0 }; - cvarName.append(SlotInfo->weaponName); + Q_snprintf(cvarName, sizeof(cvarName), "af_distance_%s", SlotInfo->weaponName); - this->m_af_distance[WeaponID] = gAccuracyUtil.CvarRegister(cvarName.c_str(), "8192.0"); + this->m_af_distance[WeaponID] = gAccuracyUtil.CvarRegister(cvarName, "8192.0"); - cvarName = "af_accuracy_"; + Q_snprintf(cvarName, sizeof(cvarName), "af_accuracy_%s", SlotInfo->weaponName); - cvarName.append(SlotInfo->weaponName); - - this->m_af_accuracy[WeaponID] = gAccuracyUtil.CvarRegister(cvarName.c_str(), "9999.0"); + this->m_af_accuracy[WeaponID] = gAccuracyUtil.CvarRegister(cvarName, "9999.0"); #ifdef ACCURACY_ENABLE_RECOIL_CONTROL - cvarName = "af_recoil_"; - - cvarName.append(SlotInfo->weaponName); + Q_snprintf(cvarName, sizeof(cvarName), "af_recoil_%s", SlotInfo->weaponName); - this->m_af_recoil[WeaponID] = gAccuracyUtil.CvarRegister(cvarName.c_str(), "1.0"); + this->m_af_recoil[WeaponID] = gAccuracyUtil.CvarRegister(cvarName, "1.0"); #endif } } @@ -51,7 +47,15 @@ void CAccuracyFix::ServerActivate() } } - gAccuracyUtil.ServerCommand("exec %s/accuracyfix.cfg", gAccuracyUtil.GetPath()); + auto Path = gAccuracyUtil.GetPath(); + + if (Path) + { + if (Path[0u] != '\0') + { + gAccuracyUtil.ServerCommand("exec %s/accuracyfix.cfg", Path); + } + } } #ifdef ACCURACY_ENABLE_RECOIL_CONTROL @@ -123,12 +127,7 @@ void CAccuracyFix::TraceLine(const float* vStart, const float* vEnd, int fNoMons g_engfuncs.pfnMakeVectors(pentToSkip->v.v_angle); - auto vEndRes = Vector - ( - (vStart[0] + (gpGlobals->v_forward[0] * fwdVelocity)), - (vStart[1] + (gpGlobals->v_forward[1] * fwdVelocity)), - (vStart[2] + (gpGlobals->v_forward[2] * fwdVelocity)) - ); + auto vEndRes = (Vector)vStart + gpGlobals->v_forward * fwdVelocity; g_engfuncs.pfnTraceLine(vStart, vEndRes, fNoMonsters, pentToSkip, ptr); } diff --git a/AccuracyFix/AccuracyUtil.cpp b/AccuracyFix/AccuracyUtil.cpp index 2662ba0..9bfbd8a 100644 --- a/AccuracyFix/AccuracyUtil.cpp +++ b/AccuracyFix/AccuracyUtil.cpp @@ -4,9 +4,9 @@ CAccuracyUtil gAccuracyUtil; cvar_t* CAccuracyUtil::CvarRegister(const char* Name, const char* Value) { - cvar_t* CvarPointer = g_engfuncs.pfnCVarGetPointer(Name); + cvar_t* pCvar = g_engfuncs.pfnCVarGetPointer(Name); - if (CvarPointer == nullptr) + if (pCvar == nullptr) { this->m_CvarData[Name].name = Name; @@ -16,15 +16,15 @@ cvar_t* CAccuracyUtil::CvarRegister(const char* Name, const char* Value) g_engfuncs.pfnCVarRegister(&this->m_CvarData[Name]); - CvarPointer = g_engfuncs.pfnCVarGetPointer(this->m_CvarData[Name].name); + pCvar = g_engfuncs.pfnCVarGetPointer(this->m_CvarData[Name].name); - if (CvarPointer != nullptr) + if (pCvar != nullptr) { - g_engfuncs.pfnCvar_DirectSet(CvarPointer, Value); + g_engfuncs.pfnCvar_DirectSet(pCvar, Value); } } - return CvarPointer; + return pCvar; } const char* CAccuracyUtil::GetPath()