mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-01 09:35:37 +03:00
Implemented optional CVar sv_tags for sets a string defining the "gametags" for this server to allows users/scripts to filter in the matchmaking/server-browser interfaces based on the value
This commit is contained in:
parent
f29d6c5769
commit
76cbd2c140
@ -55,6 +55,7 @@ This means that plugins that do binary code analysis (Orpheu for example) probab
|
|||||||
<li>sv_rehlds_local_gametime <1|0> // A feature of local gametime which decrease "lags" if you run same map for a long time. Default: 0
|
<li>sv_rehlds_local_gametime <1|0> // A feature of local gametime which decrease "lags" if you run same map for a long time. Default: 0
|
||||||
<li>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.
|
<li>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.
|
||||||
<li>sv_usercmd_custom_random_seed // When enabled server will populate an additional random seed independent of the client. Default: 0
|
<li>sv_usercmd_custom_random_seed // When enabled server will populate an additional random seed independent of the client. Default: 0
|
||||||
|
<li>sv_tags <comma-delimited string list of tags> // Sets a string defining the "gametags" for this server, this is optional, but if it is set it allows users/scripts to filter in the matchmaking/server-browser interfaces based on the value. Default: ""
|
||||||
</ul>
|
</ul>
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
|
@ -366,6 +366,7 @@ extern cvar_t sv_visiblemaxplayers;
|
|||||||
extern cvar_t sv_downloadurl;
|
extern cvar_t sv_downloadurl;
|
||||||
extern cvar_t sv_allow_dlfile;
|
extern cvar_t sv_allow_dlfile;
|
||||||
extern cvar_t sv_version;
|
extern cvar_t sv_version;
|
||||||
|
extern cvar_t sv_tags;
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
extern cvar_t sv_echo_unknown_cmd;
|
extern cvar_t sv_echo_unknown_cmd;
|
||||||
extern cvar_t sv_auto_precache_sounds_in_models;
|
extern cvar_t sv_auto_precache_sounds_in_models;
|
||||||
|
@ -193,6 +193,8 @@ cvar_t sv_version = { "sv_version", "", FCVAR_SERVER, 0.0f, NULL };
|
|||||||
cvar_t sv_version = {"sv_version", "", 0, 0.0f, NULL};
|
cvar_t sv_version = {"sv_version", "", 0, 0.0f, NULL};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
cvar_t sv_tags = { "sv_tags", "", 0, 0.0f, NULL };
|
||||||
|
|
||||||
cvar_t sv_rcon_minfailures = { "sv_rcon_minfailures", "5", 0, 0.0f, NULL };
|
cvar_t sv_rcon_minfailures = { "sv_rcon_minfailures", "5", 0, 0.0f, NULL };
|
||||||
cvar_t sv_rcon_maxfailures = { "sv_rcon_maxfailures", "10", 0, 0.0f, NULL };
|
cvar_t sv_rcon_maxfailures = { "sv_rcon_maxfailures", "10", 0, 0.0f, NULL };
|
||||||
cvar_t sv_rcon_minfailuretime = { "sv_rcon_minfailuretime", "30", 0, 0.0f, NULL };
|
cvar_t sv_rcon_minfailuretime = { "sv_rcon_minfailuretime", "30", 0, 0.0f, NULL };
|
||||||
@ -8258,6 +8260,7 @@ void SV_Init(void)
|
|||||||
Cvar_RegisterVariable(&sv_version);
|
Cvar_RegisterVariable(&sv_version);
|
||||||
Cvar_RegisterVariable(&sv_allow_dlfile);
|
Cvar_RegisterVariable(&sv_allow_dlfile);
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
|
Cvar_RegisterVariable(&sv_tags);
|
||||||
Cvar_RegisterVariable(&sv_force_ent_intersection);
|
Cvar_RegisterVariable(&sv_force_ent_intersection);
|
||||||
Cvar_RegisterVariable(&sv_echo_unknown_cmd);
|
Cvar_RegisterVariable(&sv_echo_unknown_cmd);
|
||||||
Cvar_RegisterVariable(&sv_auto_precache_sounds_in_models);
|
Cvar_RegisterVariable(&sv_auto_precache_sounds_in_models);
|
||||||
|
@ -232,6 +232,10 @@ CSteam3Server::CSteam3Server() :
|
|||||||
m_CallbackLogonFailure(this, &CSteam3Server::OnLogonFailure),
|
m_CallbackLogonFailure(this, &CSteam3Server::OnLogonFailure),
|
||||||
m_SteamIDGS(1, 0, k_EUniverseInvalid, k_EAccountTypeInvalid)
|
m_SteamIDGS(1, 0, k_EUniverseInvalid, k_EAccountTypeInvalid)
|
||||||
{
|
{
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
m_GameTagsData[0] = '\0';
|
||||||
|
#endif
|
||||||
|
|
||||||
m_bHasActivePlayers = false;
|
m_bHasActivePlayers = false;
|
||||||
m_bWantToBeSecure = false;
|
m_bWantToBeSecure = false;
|
||||||
m_bLanOnly = false;
|
m_bLanOnly = false;
|
||||||
@ -499,6 +503,21 @@ void CSteam3Server::RunFrame()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CSteam3Server::UpdateGameTags()
|
||||||
|
{
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
if (!sv_tags.string[0])
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (m_GameTagsData[0] && !Q_stricmp(m_GameTagsData, sv_tags.string))
|
||||||
|
return;
|
||||||
|
|
||||||
|
Q_strlcpy(m_GameTagsData, sv_tags.string);
|
||||||
|
Q_strlwr(m_GameTagsData);
|
||||||
|
CRehldsPlatformHolder::get()->SteamGameServer()->SetGameTags(m_GameTagsData);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void CSteam3Server::SendUpdatedServerDetails()
|
void CSteam3Server::SendUpdatedServerDetails()
|
||||||
{
|
{
|
||||||
int botCount = 0;
|
int botCount = 0;
|
||||||
@ -521,6 +540,8 @@ void CSteam3Server::SendUpdatedServerDetails()
|
|||||||
CRehldsPlatformHolder::get()->SteamGameServer()->SetBotPlayerCount(botCount);
|
CRehldsPlatformHolder::get()->SteamGameServer()->SetBotPlayerCount(botCount);
|
||||||
CRehldsPlatformHolder::get()->SteamGameServer()->SetServerName(Cvar_VariableString("hostname"));
|
CRehldsPlatformHolder::get()->SteamGameServer()->SetServerName(Cvar_VariableString("hostname"));
|
||||||
CRehldsPlatformHolder::get()->SteamGameServer()->SetMapName(g_psv.name);
|
CRehldsPlatformHolder::get()->SteamGameServer()->SetMapName(g_psv.name);
|
||||||
|
|
||||||
|
UpdateGameTags();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSteam3Client::Shutdown()
|
void CSteam3Client::Shutdown()
|
||||||
|
@ -54,6 +54,8 @@ protected:
|
|||||||
bool InitModule();
|
bool InitModule();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define MAX_STEAM_TAGS_LENGTH 128 // Steam doesn't send tags string more than 128 bytes
|
||||||
|
|
||||||
class CSteam3Server: public CSteam3
|
class CSteam3Server: public CSteam3
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -71,6 +73,10 @@ protected:
|
|||||||
bool m_bLanOnly;
|
bool m_bLanOnly;
|
||||||
CSteamID m_SteamIDGS;
|
CSteamID m_SteamIDGS;
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
char m_GameTagsData[MAX_STEAM_TAGS_LENGTH];
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
NOBODY void SetServerType();
|
NOBODY void SetServerType();
|
||||||
@ -96,6 +102,7 @@ public:
|
|||||||
void NotifyOfLevelChange(bool bForce);
|
void NotifyOfLevelChange(bool bForce);
|
||||||
void RunFrame();
|
void RunFrame();
|
||||||
void SendUpdatedServerDetails();
|
void SendUpdatedServerDetails();
|
||||||
|
void UpdateGameTags();
|
||||||
};
|
};
|
||||||
|
|
||||||
class CSteam3Client: public CSteam3
|
class CSteam3Client: public CSteam3
|
||||||
|
@ -15,5 +15,7 @@ void check_size() {
|
|||||||
void checkSizesStatic() {
|
void checkSizesStatic() {
|
||||||
CHECK_TYPE_SIZE(client_t, 0x5018, 0x4EF4);
|
CHECK_TYPE_SIZE(client_t, 0x5018, 0x4EF4);
|
||||||
CHECK_TYPE_SIZE(userfilter_t, 0x20, 0x18);
|
CHECK_TYPE_SIZE(userfilter_t, 0x20, 0x18);
|
||||||
|
#ifndef REHLDS_FIXES
|
||||||
CHECK_TYPE_SIZE(CSteam3Server, 0x90, 0xA8);
|
CHECK_TYPE_SIZE(CSteam3Server, 0x90, 0xA8);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user