mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-14 05:41:02 +00:00
Implement EXECVERSION consvar to invalidate previous versions' default config values
This commit is contained in:
parent
7852e418d5
commit
5b3a1e0c55
3 changed files with 242 additions and 2 deletions
212
src/command.c
212
src/command.c
|
@ -49,6 +49,7 @@ static void COM_Wait_f(void);
|
||||||
static void COM_Help_f(void);
|
static void COM_Help_f(void);
|
||||||
static void COM_Toggle_f(void);
|
static void COM_Toggle_f(void);
|
||||||
|
|
||||||
|
static boolean CV_FilterVarByVersion(consvar_t *v, const char *valstr);
|
||||||
static boolean CV_Command(void);
|
static boolean CV_Command(void);
|
||||||
static consvar_t *CV_FindVar(const char *name);
|
static consvar_t *CV_FindVar(const char *name);
|
||||||
static const char *CV_StringValue(const char *var_name);
|
static const char *CV_StringValue(const char *var_name);
|
||||||
|
@ -62,6 +63,17 @@ CV_PossibleValue_t CV_YesNo[] = {{0, "No"}, {1, "Yes"}, {0, NULL}};
|
||||||
CV_PossibleValue_t CV_Unsigned[] = {{0, "MIN"}, {999999999, "MAX"}, {0, NULL}};
|
CV_PossibleValue_t CV_Unsigned[] = {{0, "MIN"}, {999999999, "MAX"}, {0, NULL}};
|
||||||
CV_PossibleValue_t CV_Natural[] = {{1, "MIN"}, {999999999, "MAX"}, {0, NULL}};
|
CV_PossibleValue_t CV_Natural[] = {{1, "MIN"}, {999999999, "MAX"}, {0, NULL}};
|
||||||
|
|
||||||
|
// Filter consvars by MODVERSION
|
||||||
|
// First implementation is 26 (2.1.21), so earlier configs default at 25 (2.1.20)
|
||||||
|
// Also set CV_HIDEN during runtime, after config is loaded
|
||||||
|
consvar_t cv_execversion = {"execversion","25",CV_SAVE,CV_Unsigned, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
|
||||||
|
// for default joyaxis detection
|
||||||
|
static boolean joyaxis_default = false;
|
||||||
|
static boolean joyaxis2_default = false;
|
||||||
|
static INT32 joyaxis_count = 0;
|
||||||
|
static INT32 joyaxis2_count = 0;
|
||||||
|
|
||||||
#define COM_BUF_SIZE 8192 // command buffer size
|
#define COM_BUF_SIZE 8192 // command buffer size
|
||||||
#define MAX_ALIAS_RECURSION 100 // max recursion allowed for aliases
|
#define MAX_ALIAS_RECURSION 100 // max recursion allowed for aliases
|
||||||
|
|
||||||
|
@ -1568,6 +1580,199 @@ void CV_AddValue(consvar_t *var, INT32 increment)
|
||||||
var->changed = 1; // user has changed it now
|
var->changed = 1; // user has changed it now
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CV_InitFilterVar(void)
|
||||||
|
{
|
||||||
|
joyaxis_default = joyaxis2_default = true;
|
||||||
|
joyaxis_count = joyaxis2_count = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static boolean CV_FilterJoyAxisVars(consvar_t *v, const char *valstr)
|
||||||
|
{
|
||||||
|
// If ALL axis settings are previous defaults, set them to the new defaults
|
||||||
|
// MODVERSION < 26 (2.1.21)
|
||||||
|
|
||||||
|
if (joyaxis_default)
|
||||||
|
{
|
||||||
|
#if !defined (_WII) && !defined (WMINPUT)
|
||||||
|
if (!stricmp(v->name, "joyaxis_turn"))
|
||||||
|
{
|
||||||
|
if (joyaxis_count > 6) return false;
|
||||||
|
// we're currently setting the new defaults, don't interfere
|
||||||
|
else if (joyaxis_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "X-Axis")) joyaxis_count++;
|
||||||
|
else joyaxis_default = false;
|
||||||
|
}
|
||||||
|
#if !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis_move"))
|
||||||
|
{
|
||||||
|
if (joyaxis_count > 6) return false;
|
||||||
|
else if (joyaxis_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "Y-Axis")) joyaxis_count++;
|
||||||
|
else joyaxis_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if !defined (_arch_dreamcast) && !defined (_XBOX) && !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis_side"))
|
||||||
|
{
|
||||||
|
if (joyaxis_count > 6) return false;
|
||||||
|
else if (joyaxis_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "Z-Axis")) joyaxis_count++;
|
||||||
|
else joyaxis_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if !defined (_XBOX) && !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis_look"))
|
||||||
|
{
|
||||||
|
if (joyaxis_count > 6) return false;
|
||||||
|
else if (joyaxis_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "None")) joyaxis_count++;
|
||||||
|
else joyaxis_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!stricmp(v->name, "joyaxis_fire")
|
||||||
|
|| !stricmp(v->name, "joyaxis_firenormal"))
|
||||||
|
{
|
||||||
|
if (joyaxis_count > 6) return false;
|
||||||
|
else if (joyaxis_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "None")) joyaxis_count++;
|
||||||
|
else joyaxis_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
// reset all axis settings to defaults
|
||||||
|
if (joyaxis_count == 6)
|
||||||
|
{
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_turnaxis.name, cv_turnaxis.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_moveaxis.name, cv_moveaxis.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_sideaxis.name, cv_sideaxis.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_lookaxis.name, cv_lookaxis.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_fireaxis.name, cv_fireaxis.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_firenaxis.name, cv_firenaxis.defaultvalue));
|
||||||
|
joyaxis_count++;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (joyaxis2_default)
|
||||||
|
{
|
||||||
|
#if !defined (_WII) && !defined (WMINPUT)
|
||||||
|
if (!stricmp(v->name, "joyaxis2_turn"))
|
||||||
|
{
|
||||||
|
if (joyaxis2_count > 6) return false;
|
||||||
|
// we're currently setting the new defaults, don't interfere
|
||||||
|
else if (joyaxis2_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "X-Axis")) joyaxis2_count++;
|
||||||
|
else joyaxis2_default = false;
|
||||||
|
}
|
||||||
|
// #if !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis2_move"))
|
||||||
|
{
|
||||||
|
if (joyaxis2_count > 6) return false;
|
||||||
|
else if (joyaxis2_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "Y-Axis")) joyaxis2_count++;
|
||||||
|
else joyaxis2_default = false;
|
||||||
|
}
|
||||||
|
// #endif
|
||||||
|
#if !defined (_arch_dreamcast) && !defined (_XBOX) && !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis2_side"))
|
||||||
|
{
|
||||||
|
if (joyaxis2_count > 6) return false;
|
||||||
|
else if (joyaxis2_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "Z-Axis")) joyaxis2_count++;
|
||||||
|
else joyaxis2_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if !defined (_XBOX) // && !defined (PSP)
|
||||||
|
if (!stricmp(v->name, "joyaxis2_look"))
|
||||||
|
{
|
||||||
|
if (joyaxis2_count > 6) return false;
|
||||||
|
else if (joyaxis2_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "None")) joyaxis2_count++;
|
||||||
|
else joyaxis2_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!stricmp(v->name, "joyaxis2_fire")
|
||||||
|
|| !stricmp(v->name, "joyaxis2_firenormal"))
|
||||||
|
{
|
||||||
|
if (joyaxis2_count > 6) return false;
|
||||||
|
else if (joyaxis2_count == 6) return true;
|
||||||
|
|
||||||
|
if (!stricmp(valstr, "None")) joyaxis2_count++;
|
||||||
|
else joyaxis2_default = false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// reset all axis settings to defaults
|
||||||
|
if (joyaxis2_count == 6)
|
||||||
|
{
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_turnaxis2.name, cv_turnaxis2.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_moveaxis2.name, cv_moveaxis2.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_sideaxis2.name, cv_sideaxis2.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_lookaxis2.name, cv_lookaxis2.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_fireaxis2.name, cv_fireaxis2.defaultvalue));
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_firenaxis2.name, cv_firenaxis2.defaultvalue));
|
||||||
|
joyaxis2_count++;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// we haven't reached our counts yet, or we're not default
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static boolean CV_FilterVarByVersion(consvar_t *v, const char *valstr)
|
||||||
|
{
|
||||||
|
// True means allow the CV change, False means block it
|
||||||
|
|
||||||
|
// We only care about CV_SAVE because this filters the user's config files
|
||||||
|
// We do this same check in CV_Command
|
||||||
|
if (!(v->flags & CV_SAVE))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// We go by MODVERSION here
|
||||||
|
if (cv_execversion.value < 26) // 26 = 2.1.21
|
||||||
|
{
|
||||||
|
// MOUSE SETTINGS
|
||||||
|
// alwaysfreelook split between first and third person (chasefreelook)
|
||||||
|
// mousemove was on by default, which invalidates the current approach
|
||||||
|
if (!stricmp(v->name, "alwaysfreelook"))
|
||||||
|
return false;
|
||||||
|
if (!stricmp(v->name, "mousemove"))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// mousesens was changed from 35 to 20 due to oversensitivity
|
||||||
|
if ((!stricmp(v->name, "mousesens")
|
||||||
|
|| !stricmp(v->name, "mousesens2")
|
||||||
|
|| !stricmp(v->name, "mouseysens")
|
||||||
|
|| !stricmp(v->name, "mouseysens2"))
|
||||||
|
&& atoi(valstr) == 35)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// JOYSTICK DEFAULTS
|
||||||
|
// use_joystick was changed from 0 to 1 to automatically use a joystick if available
|
||||||
|
#if defined(HAVE_SDL) || defined(_WINDOWS)
|
||||||
|
if ((!stricmp(v->name, "use_joystick")
|
||||||
|
|| !stricmp(v->name, "use_joystick2"))
|
||||||
|
&& atoi(valstr) == 0)
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// axis defaults were changed to be friendly to 360 controllers
|
||||||
|
// if ALL axis settings are defaults, then change them to new values
|
||||||
|
if (!CV_FilterJoyAxisVars(v, valstr))
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/** Displays or changes a variable from the console.
|
/** Displays or changes a variable from the console.
|
||||||
* Since the user is presumed to have been directly responsible
|
* Since the user is presumed to have been directly responsible
|
||||||
* for this change, the variable is marked as changed this game.
|
* for this change, the variable is marked as changed this game.
|
||||||
|
@ -1592,8 +1797,11 @@ static boolean CV_Command(void)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
CV_Set(v, COM_Argv(1));
|
if (!(v->flags & CV_SAVE) || CV_FilterVarByVersion(v, COM_Argv(1)))
|
||||||
v->changed = 1; // now it's been changed by (presumably) the user
|
{
|
||||||
|
CV_Set(v, COM_Argv(1));
|
||||||
|
v->changed = 1; // now it's been changed by (presumably) the user
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -125,6 +125,12 @@ extern CV_PossibleValue_t CV_OnOff[];
|
||||||
extern CV_PossibleValue_t CV_YesNo[];
|
extern CV_PossibleValue_t CV_YesNo[];
|
||||||
extern CV_PossibleValue_t CV_Unsigned[];
|
extern CV_PossibleValue_t CV_Unsigned[];
|
||||||
extern CV_PossibleValue_t CV_Natural[];
|
extern CV_PossibleValue_t CV_Natural[];
|
||||||
|
|
||||||
|
// Filter consvars by version
|
||||||
|
extern consvar_t cv_execversion;
|
||||||
|
|
||||||
|
void CV_InitFilterVar(void);
|
||||||
|
|
||||||
// register a variable for use at the console
|
// register a variable for use at the console
|
||||||
void CV_RegisterVar(consvar_t *variable);
|
void CV_RegisterVar(consvar_t *variable);
|
||||||
|
|
||||||
|
|
26
src/m_misc.c
26
src/m_misc.c
|
@ -37,6 +37,7 @@
|
||||||
#include "d_main.h"
|
#include "d_main.h"
|
||||||
#include "m_argv.h"
|
#include "m_argv.h"
|
||||||
#include "i_system.h"
|
#include "i_system.h"
|
||||||
|
#include "command.h" // cv_execversion
|
||||||
|
|
||||||
#include "m_anigif.h"
|
#include "m_anigif.h"
|
||||||
|
|
||||||
|
@ -440,7 +441,18 @@ void Command_LoadConfig_f(void)
|
||||||
|
|
||||||
strcpy(configfile, COM_Argv(1));
|
strcpy(configfile, COM_Argv(1));
|
||||||
FIL_ForceExtension(configfile, ".cfg");
|
FIL_ForceExtension(configfile, ".cfg");
|
||||||
|
|
||||||
|
// temporarily reset execversion to default
|
||||||
|
cv_execversion.flags &= ~CV_HIDEN;
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_execversion.name, cv_execversion.defaultvalue));
|
||||||
|
CV_InitFilterVar();
|
||||||
|
|
||||||
|
// exec the config
|
||||||
COM_BufInsertText(va("exec \"%s\"\n", configfile));
|
COM_BufInsertText(va("exec \"%s\"\n", configfile));
|
||||||
|
|
||||||
|
// don't filter anymore vars and don't let this convsvar be changed
|
||||||
|
COM_BufInsertText(va("%s \"%d\"\n", cv_execversion.name, MODVERSION));
|
||||||
|
cv_execversion.flags |= CV_HIDEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Saves the current configuration and loads another.
|
/** Saves the current configuration and loads another.
|
||||||
|
@ -477,10 +489,20 @@ void M_FirstLoadConfig(void)
|
||||||
// load default control
|
// load default control
|
||||||
G_Controldefault();
|
G_Controldefault();
|
||||||
|
|
||||||
|
// temporarily reset execversion to default
|
||||||
|
// we shouldn't need to do this, but JUST in case...
|
||||||
|
cv_execversion.flags &= ~CV_HIDEN;
|
||||||
|
COM_BufInsertText(va("%s \"%s\"\n", cv_execversion.name, cv_execversion.defaultvalue));
|
||||||
|
CV_InitFilterVar();
|
||||||
|
|
||||||
// load config, make sure those commands doesnt require the screen...
|
// load config, make sure those commands doesnt require the screen...
|
||||||
COM_BufInsertText(va("exec \"%s\"\n", configfile));
|
COM_BufInsertText(va("exec \"%s\"\n", configfile));
|
||||||
// no COM_BufExecute() needed; that does it right away
|
// no COM_BufExecute() needed; that does it right away
|
||||||
|
|
||||||
|
// don't filter anymore vars and don't let this convsvar be changed
|
||||||
|
COM_BufInsertText(va("%s \"%d\"\n", cv_execversion.name, MODVERSION));
|
||||||
|
cv_execversion.flags |= CV_HIDEN;
|
||||||
|
|
||||||
// make sure I_Quit() will write back the correct config
|
// make sure I_Quit() will write back the correct config
|
||||||
// (do not write back the config if it crash before)
|
// (do not write back the config if it crash before)
|
||||||
gameconfig_loaded = true;
|
gameconfig_loaded = true;
|
||||||
|
@ -536,6 +558,10 @@ void M_SaveConfig(const char *filename)
|
||||||
// header message
|
// header message
|
||||||
fprintf(f, "// SRB2 configuration file.\n");
|
fprintf(f, "// SRB2 configuration file.\n");
|
||||||
|
|
||||||
|
// print execversion FIRST, because subsequent consvars need to be filtered
|
||||||
|
// always print current MODVERSION
|
||||||
|
fprintf(f, "%s \"%d\"\n", cv_execversion.name, MODVERSION);
|
||||||
|
|
||||||
// FIXME: save key aliases if ever implemented..
|
// FIXME: save key aliases if ever implemented..
|
||||||
|
|
||||||
CV_SaveVariables(f);
|
CV_SaveVariables(f);
|
||||||
|
|
Loading…
Reference in a new issue