From 39b441099c8c4d4c29ca71434a43ba30698487dd Mon Sep 17 00:00:00 2001 From: Sergey Shorokhov Date: Mon, 14 Jun 2021 02:19:51 +0300 Subject: [PATCH] Implement CVar sv_usercmd_custom_random_seed (#837) --- README.md | 1 + rehlds/engine/server.h | 1 + rehlds/engine/sv_main.cpp | 2 ++ rehlds/engine/sv_user.cpp | 8 ++++++++ 4 files changed, 12 insertions(+) diff --git a/README.md b/README.md index 32f395c12..52e965ce4 100644 --- a/README.md +++ b/README.md @@ -53,6 +53,7 @@ This means that plugins that do binary code analysis (Orpheu for example) probab
  • sv_rehlds_attachedentities_playeranimationspeed_fix // Fixes bug with gait animation speed increase when player has some attached entities (aiments). Can cause animation lags when cl_updaterate is low. Default: 0
  • sv_rehlds_maxclients_from_single_ip // Limit number of connections from the single ip address. Default: 5
  • sv_use_entity_file // Use custom entity file for a map. Path to an entity file will be "maps/[map name].ent". 0 - use original entities. 1 - use .ent files from maps directory. 2 - use .ent files from maps directory and create new .ent file if not exist. +
  • sv_usercmd_custom_random_seed // When enabled server will populate an additional random seed independent of the client. Default: 0 diff --git a/rehlds/engine/server.h b/rehlds/engine/server.h index b94f7c4e2..23c72c8f1 100644 --- a/rehlds/engine/server.h +++ b/rehlds/engine/server.h @@ -376,6 +376,7 @@ extern cvar_t sv_rehlds_userinfo_transmitted_fields; extern cvar_t sv_rehlds_attachedentities_playeranimationspeed_fix; extern cvar_t sv_rehlds_local_gametime; extern cvar_t sv_rehlds_send_mapcycle; +extern cvar_t sv_usercmd_custom_random_seed; #endif extern int sv_playermodel; diff --git a/rehlds/engine/sv_main.cpp b/rehlds/engine/sv_main.cpp index 904053a2f..5988519a3 100644 --- a/rehlds/engine/sv_main.cpp +++ b/rehlds/engine/sv_main.cpp @@ -209,6 +209,7 @@ cvar_t sv_rehlds_local_gametime = {"sv_rehlds_local_gametime", "0", 0, 0.0f, nul cvar_t sv_rehlds_send_mapcycle = { "sv_rehlds_send_mapcycle", "0", 0, 0.0f, nullptr }; cvar_t sv_rehlds_maxclients_from_single_ip = { "sv_rehlds_maxclients_from_single_ip", "5", 0, 5.0f, nullptr }; cvar_t sv_use_entity_file = { "sv_use_entity_file", "0", 0, 0.0f, nullptr }; +cvar_t sv_usercmd_custom_random_seed = { "sv_usercmd_custom_random_seed", "0", 0, 0.0f, nullptr }; #endif delta_t *SV_LookupDelta(char *name) @@ -8016,6 +8017,7 @@ void SV_Init(void) Cvar_RegisterVariable(&sv_rollspeed); Cvar_RegisterVariable(&sv_rollangle); Cvar_RegisterVariable(&sv_use_entity_file); + Cvar_RegisterVariable(&sv_usercmd_custom_random_seed); #endif for (int i = 0; i < MAX_MODELS; i++) diff --git a/rehlds/engine/sv_user.cpp b/rehlds/engine/sv_user.cpp index a50862b93..16a48c450 100644 --- a/rehlds/engine/sv_user.cpp +++ b/rehlds/engine/sv_user.cpp @@ -782,6 +782,14 @@ void SV_RunCmd(usercmd_t *ucmd, int random_seed) if (!host_client->fakeclient) SV_SetupMove(host_client); +#ifdef REHLDS_FIXES + if (sv_usercmd_custom_random_seed.value) + { + float fltTimeNow = float(Sys_FloatTime() * 1000.0); + random_seed = *reinterpret_cast((char *)&fltTimeNow); + } +#endif + gEntityInterface.pfnCmdStart(sv_player, ucmd, random_seed); frametime = float(ucmd->msec * 0.001); host_client->svtimebase = frametime + host_client->svtimebase;