Don't need to run CBuf_Execute. Game does it itself.

* How did I forget to remember that for almost a year..
* Connect and disconnect commands also fixed now.
This commit is contained in:
Marvin D 2022-08-19 22:25:26 +02:00
parent 6764b5e56e
commit eeec292238
5 changed files with 5 additions and 5 deletions

View File

@ -361,7 +361,7 @@ void RuntimePtc_Init() /* .TEXT */
#ifndef CLIENT_DLL
FairFight_Init.Offset(0x0).FindPatternSelf("0F 87", CMemory::Direction::DOWN, 200).Patch({ 0x0F, 0x85 }); // JA --> JNZ | Prevent 'FairFight' anti-cheat from initializing on the server by comparing RAX against 0x0 instead. Init will crash since the plugins aren't shipped.
#endif // !CLIENT_DLL
SCR_BeginLoadingPlaque.Offset(0x1AD).FindPatternSelf("75 27", CMemory::Direction::DOWN).Patch({ 0xEB, 0x27 }); // JNE --> JMP | Prevent connect command from crashing by invalid call to UI function.
//SCR_BeginLoadingPlaque.Offset(0x1AD).FindPatternSelf("75 27", CMemory::Direction::DOWN).Patch({ 0xEB, 0x27 }); // JNE --> JMP | Prevent connect command from crashing by invalid call to UI function.
p_SQVM_CompileError.Offset(0x0).FindPatternSelf("41 B0 01", CMemory::Direction::DOWN, 400).Patch({ 0x41, 0xB0, 0x00 }); // MOV --> MOV | Set script error level to 0 (not severe): 'mov r8b, 0'.
p_SQVM_CompileError.Offset(0xE0).FindPatternSelf("E8", CMemory::Direction::DOWN, 200).Patch({ 0x90, 0x90, 0x90, 0x90, 0x90 }); // CAL --> NOP | TODO: causes errors on client script error. Research required (same function as soft error but that one doesn't crash).
#else

View File

@ -625,7 +625,7 @@ void CBrowser::SendHostingPostRequest(void)
void CBrowser::ProcessCommand(const char* pszCommand) const
{
Cbuf_AddText(Cbuf_GetCurrentPlayer(), pszCommand, cmd_source_t::kCommandSrcCode);
g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
//g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
}
//-----------------------------------------------------------------------------

View File

@ -535,7 +535,7 @@ void CConsole::ProcessCommand(const char* pszCommand)
DevMsg(eDLL_T::COMMON, "] %s\n", pszCommand);
Cbuf_AddText(Cbuf_GetCurrentPlayer(), pszCommand, cmd_source_t::kCommandSrcCode);
g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
//g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
m_nHistoryPos = -1;
for (size_t i = m_vHistory.size(); i-- > 0; )

View File

@ -90,7 +90,7 @@ void CServerListManager::ConnectToServer(const string& svServer, const string& s
void CServerListManager::ProcessCommand(const char* pszCommand) const
{
Cbuf_AddText(Cbuf_GetCurrentPlayer(), pszCommand, cmd_source_t::kCommandSrcCode);
g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
//g_DelayedCallTask->AddFunc(Cbuf_Execute, 0); // Run in main thread.
}
CServerListManager* g_pServerListManager = new CServerListManager();

View File

@ -136,7 +136,7 @@ DWORD __stdcall ProcessConsoleWorker(LPVOID)
// Execute the command.
Cbuf_AddText(Cbuf_GetCurrentPlayer(), sCommand.c_str(), cmd_source_t::kCommandSrcCode);
g_DelayedCallTask->AddFunc(Cbuf_Execute, 0);
//g_DelayedCallTask->AddFunc(Cbuf_Execute, 0);
sCommand.clear();