mirror of
https://github.com/DrBeef/ioq3quest.git
synced 2024-11-29 07:11:44 +00:00
Don't let VMs change engine latch cvars immediately
If a VM increases sv_maxclients while a server is running the engine will crash. The value should be latched until engine decides to update the cvar; the same as when a user sets it.
This commit is contained in:
parent
adef4e6c9e
commit
78ca670d4f
1 changed files with 20 additions and 9 deletions
|
@ -638,8 +638,11 @@ Cvar_SetSafe
|
|||
void Cvar_SetSafe( const char *var_name, const char *value )
|
||||
{
|
||||
int flags = Cvar_Flags( var_name );
|
||||
qboolean force = qtrue;
|
||||
|
||||
if((flags != CVAR_NONEXISTENT) && (flags & CVAR_PROTECTED))
|
||||
if ( flags != CVAR_NONEXISTENT )
|
||||
{
|
||||
if ( flags & CVAR_PROTECTED )
|
||||
{
|
||||
if( value )
|
||||
Com_Error( ERR_DROP, "Restricted source tried to set "
|
||||
|
@ -649,7 +652,15 @@ void Cvar_SetSafe( const char *var_name, const char *value )
|
|||
"modify \"%s\"", var_name );
|
||||
return;
|
||||
}
|
||||
Cvar_Set( var_name, value );
|
||||
|
||||
// don't let VMs or server change engine latched cvars instantly
|
||||
if ( ( flags & CVAR_LATCH ) && !( flags & CVAR_VM_CREATED ) )
|
||||
{
|
||||
force = qfalse;
|
||||
}
|
||||
}
|
||||
|
||||
Cvar_Set2 (var_name, value, force);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in a new issue