aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--NorthstarDedicatedTest/maxplayers.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/NorthstarDedicatedTest/maxplayers.cpp b/NorthstarDedicatedTest/maxplayers.cpp
index e7d23032..ed2ac26a 100644
--- a/NorthstarDedicatedTest/maxplayers.cpp
+++ b/NorthstarDedicatedTest/maxplayers.cpp
@@ -1,5 +1,6 @@
#include "pch.h"
#include "maxplayers.h"
+#include "gameutils.h"
// never set this to anything below 32
#define NEW_MAX_PLAYERS 64
@@ -102,8 +103,17 @@ void* StringTables_CreateStringTable_Hook(__int64 thisptr, const char* name, int
return StringTables_CreateStringTable_Original(thisptr, name, maxentries, userdatafixedsize, userdatanetworkbits, flags);
}
+bool MaxPlayersIncreaseEnabled()
+{
+ // Unrecommended: this will break compatibility with clients/servers that have it enabled.
+ return CommandLine() && !CommandLine()->CheckParm("-nomaxplayersincrease");
+}
+
void InitialiseMaxPlayersOverride_Engine(HMODULE baseAddress)
{
+ if (!MaxPlayersIncreaseEnabled())
+ return;
+
// patch GetPlayerLimits to ignore the boundary limit
ChangeOffset<unsigned char>((char*)baseAddress + 0x116458, 0xEB); // jle => jmp
@@ -308,6 +318,9 @@ __int64 __fastcall SendPropArray2_Hook(__int64 recvProp, int elements, int flags
void InitialiseMaxPlayersOverride_Server(HMODULE baseAddress)
{
+ if (!MaxPlayersIncreaseEnabled())
+ return;
+
// get required data
serverBase = GetModuleHandleA("server.dll");
RandomIntZeroMax = (decltype(RandomIntZeroMax))(GetProcAddress(GetModuleHandleA("vstdlib.dll"), "RandomIntZeroMax"));
@@ -483,6 +496,9 @@ __int64 __fastcall RecvPropArray2_Hook(__int64 recvProp, int elements, int flags
void InitialiseMaxPlayersOverride_Client(HMODULE baseAddress)
{
+ if (!MaxPlayersIncreaseEnabled())
+ return;
+
constexpr int C_PlayerResource_OriginalSize = 5768;
constexpr int C_PlayerResource_AddedSize = PlayerResource_TotalSize;
constexpr int C_PlayerResource_ModifiedSize = C_PlayerResource_OriginalSize + C_PlayerResource_AddedSize;