ref: 3e9f69932d1d7a42561cf903f4024e2cc1662ef9
parent: d57d467f53271502ebace92a3ff958ca695cd8e9
author: Simon Howard <fraggle@gmail.com>
date: Mon Oct 23 14:32:26 EDT 2006
Detect when keyboard variables are changed and convert back so that the new values are saved to the config file. Subversion-branch: /trunk/chocolate-doom Subversion-revision: 721
--- a/setup/configfile.c
+++ b/setup/configfile.c
@@ -151,10 +151,25 @@
typedef struct
{
+ // Name of the variable
char * name;
+
+ // Pointer to the location in memory of the variable
void * location;
+
+ // Type of the variable
default_type_t type;
+
+ // If this is a key value, the original integer scancode we read from
+ // the config file before translating it to the internal key value.
+ // If zero, we didn't read this value from a config file.
int untranslated;
+
+ // The value we translated the scancode into when we read the
+ // config file on startup. If the variable value is different from
+ // this, it has been changed and needs to be converted; otherwise,
+ // use the 'untranslated' value.
+ int original_translated;
} default_t;
typedef struct
@@ -166,47 +181,47 @@
static default_t doom_defaults_list[] =
{
- {"mouse_sensitivity", &mouseSensitivity, DEFAULT_INT, 0},
- {"sfx_volume",&sfxVolume, DEFAULT_INT, 0},
- {"music_volume",&musicVolume, DEFAULT_INT, 0},
- {"show_messages",&showMessages, DEFAULT_INT, 0},
+ {"mouse_sensitivity", &mouseSensitivity, DEFAULT_INT, 0, 0},
+ {"sfx_volume",&sfxVolume, DEFAULT_INT, 0, 0},
+ {"music_volume",&musicVolume, DEFAULT_INT, 0, 0},
+ {"show_messages",&showMessages, DEFAULT_INT, 0, 0},
- {"key_right",&key_right, DEFAULT_KEY, 0},
- {"key_left",&key_left, DEFAULT_KEY, 0},
- {"key_up",&key_up, DEFAULT_KEY, 0},
- {"key_down",&key_down, DEFAULT_KEY, 0},
- {"key_strafeleft",&key_strafeleft, DEFAULT_KEY, 0},
- {"key_straferight",&key_straferight, DEFAULT_KEY, 0},
+ {"key_right",&key_right, DEFAULT_KEY, 0, 0},
+ {"key_left",&key_left, DEFAULT_KEY, 0, 0},
+ {"key_up",&key_up, DEFAULT_KEY, 0, 0},
+ {"key_down",&key_down, DEFAULT_KEY, 0, 0},
+ {"key_strafeleft",&key_strafeleft, DEFAULT_KEY, 0, 0},
+ {"key_straferight",&key_straferight, DEFAULT_KEY, 0, 0},
- {"key_fire",&key_fire, DEFAULT_KEY, 0},
- {"key_use",&key_use, DEFAULT_KEY, 0},
- {"key_strafe",&key_strafe, DEFAULT_KEY, 0},
- {"key_speed",&key_speed, DEFAULT_KEY, 0},
+ {"key_fire",&key_fire, DEFAULT_KEY, 0, 0},
+ {"key_use",&key_use, DEFAULT_KEY, 0, 0},
+ {"key_strafe",&key_strafe, DEFAULT_KEY, 0, 0},
+ {"key_speed",&key_speed, DEFAULT_KEY, 0, 0},
- {"use_mouse",&usemouse, DEFAULT_INT, 0},
- {"mouseb_fire",&mousebfire, DEFAULT_INT, 0},
- {"mouseb_strafe",&mousebstrafe, DEFAULT_INT, 0},
- {"mouseb_forward",&mousebforward, DEFAULT_INT, 0},
+ {"use_mouse",&usemouse, DEFAULT_INT, 0, 0},
+ {"mouseb_fire",&mousebfire, DEFAULT_INT, 0, 0},
+ {"mouseb_strafe",&mousebstrafe, DEFAULT_INT, 0, 0},
+ {"mouseb_forward",&mousebforward, DEFAULT_INT, 0, 0},
- {"use_joystick",&usejoystick, DEFAULT_INT, 0},
- {"joyb_fire",&joybfire, DEFAULT_INT, 0},
- {"joyb_strafe",&joybstrafe, DEFAULT_INT, 0},
- {"joyb_use",&joybuse, DEFAULT_INT, 0},
- {"joyb_speed",&joybspeed, DEFAULT_INT, 0},
+ {"use_joystick",&usejoystick, DEFAULT_INT, 0, 0},
+ {"joyb_fire",&joybfire, DEFAULT_INT, 0, 0},
+ {"joyb_strafe",&joybstrafe, DEFAULT_INT, 0, 0},
+ {"joyb_use",&joybuse, DEFAULT_INT, 0, 0},
+ {"joyb_speed",&joybspeed, DEFAULT_INT, 0, 0},
- {"screenblocks",&screenblocks, DEFAULT_INT, 0},
- {"detaillevel",&detailLevel, DEFAULT_INT, 0},
+ {"screenblocks",&screenblocks, DEFAULT_INT, 0, 0},
+ {"detaillevel",&detailLevel, DEFAULT_INT, 0, 0},
- {"snd_channels",&numChannels, DEFAULT_INT, 0},
+ {"snd_channels",&numChannels, DEFAULT_INT, 0, 0},
- {"snd_musicdevice", &snd_musicdevice, DEFAULT_INT, 0},
- {"snd_sfxdevice", &snd_sfxdevice, DEFAULT_INT, 0},
- {"snd_sbport", &snd_sbport, DEFAULT_INT, 0},
- {"snd_sbirq", &snd_sbirq, DEFAULT_INT, 0},
- {"snd_sbdma", &snd_sbdma, DEFAULT_INT, 0},
- {"snd_mport", &snd_mport, DEFAULT_INT, 0},
+ {"snd_musicdevice", &snd_musicdevice, DEFAULT_INT, 0, 0},
+ {"snd_sfxdevice", &snd_sfxdevice, DEFAULT_INT, 0, 0},
+ {"snd_sbport", &snd_sbport, DEFAULT_INT, 0, 0},
+ {"snd_sbirq", &snd_sbirq, DEFAULT_INT, 0, 0},
+ {"snd_sbdma", &snd_sbdma, DEFAULT_INT, 0, 0},
+ {"snd_mport", &snd_mport, DEFAULT_INT, 0, 0},
- {"usegamma", &usegamma, DEFAULT_INT, 0},
+ {"usegamma", &usegamma, DEFAULT_INT, 0, 0},
{"chatmacro0", &chat_macros[0], DEFAULT_STRING, 0 },
{"chatmacro1", &chat_macros[1], DEFAULT_STRING, 0 },
@@ -229,17 +244,17 @@
static default_t extra_defaults_list[] =
{
- {"autoadjust_video_settings", &autoadjust_video_settings, 0, 0},
- {"fullscreen", &fullscreen, 0, 0},
- {"startup_delay", &startup_delay, 0, 0},
- {"screenmultiply", &screenmultiply, 0, 0},
- {"grabmouse", &grabmouse, 0, 0},
- {"novert", &novert, 0, 0},
- {"mouse_acceleration", &mouse_acceleration, DEFAULT_FLOAT, 0},
- {"mouse_threshold", &mouse_threshold, 0, 0},
- {"show_endoom", &show_endoom, 0, 0},
- {"vanilla_savegame_limit", &vanilla_savegame_limit, 0, 0},
- {"vanilla_demo_limit", &vanilla_demo_limit, 0, 0},
+ {"autoadjust_video_settings", &autoadjust_video_settings, DEFAULT_INT, 0, 0},
+ {"fullscreen", &fullscreen, DEFAULT_INT, 0, 0},
+ {"startup_delay", &startup_delay, DEFAULT_INT, 0, 0},
+ {"screenmultiply", &screenmultiply, DEFAULT_INT, 0, 0},
+ {"grabmouse", &grabmouse, DEFAULT_INT, 0, 0},
+ {"novert", &novert, DEFAULT_INT, 0, 0},
+ {"mouse_acceleration", &mouse_acceleration, DEFAULT_FLOAT, 0, 0},
+ {"mouse_threshold", &mouse_threshold, DEFAULT_INT, 0, 0},
+ {"show_endoom", &show_endoom, DEFAULT_INT, 0, 0},
+ {"vanilla_savegame_limit", &vanilla_savegame_limit, DEFAULT_INT, 0, 0},
+ {"vanilla_demo_limit", &vanilla_demo_limit, DEFAULT_INT, 0, 0},
#ifdef FEATURE_MULTIPLAYER
{"player_name", &net_player_name, DEFAULT_STRING, 0},
#endif
@@ -308,8 +323,12 @@
v = * (int *) defaults[i].location;
- if (defaults[i].untranslated)
+ if (defaults[i].untranslated
+ && v == defaults[i].original_translated)
{
+ // Has not been changed since the last time we
+ // read the config file.
+
v = defaults[i].untranslated;
}
else
@@ -437,6 +456,7 @@
defaults[i].untranslated = intparm;
intparm = scantokey[intparm];
+ defaults[i].original_translated = intparm;
* (int *) def->location = intparm;
break;
--- a/src/m_misc.c
+++ b/src/m_misc.c
@@ -253,10 +253,25 @@
typedef struct
{
+ // Name of the variable
char * name;
+
+ // Pointer to the location in memory of the variable
void * location;
+
+ // Type of the variable
default_type_t type;
+
+ // If this is a key value, the original integer scancode we read from
+ // the config file before translating it to the internal key value.
+ // If zero, we didn't read this value from a config file.
int untranslated;
+
+ // The value we translated the scancode into when we read the
+ // config file on startup. If the variable value is different from
+ // this, it has been changed and needs to be converted; otherwise,
+ // use the 'untranslated' value.
+ int original_translated;
} default_t;
typedef struct
@@ -268,47 +283,47 @@
static default_t doom_defaults_list[] =
{
- {"mouse_sensitivity", &mouseSensitivity, DEFAULT_INT, 0},
- {"sfx_volume",&sfxVolume, DEFAULT_INT, 0},
- {"music_volume",&musicVolume, DEFAULT_INT, 0},
- {"show_messages",&showMessages, DEFAULT_INT, 0},
+ {"mouse_sensitivity", &mouseSensitivity, DEFAULT_INT, 0, 0},
+ {"sfx_volume",&sfxVolume, DEFAULT_INT, 0, 0},
+ {"music_volume",&musicVolume, DEFAULT_INT, 0, 0},
+ {"show_messages",&showMessages, DEFAULT_INT, 0, 0},
- {"key_right",&key_right, DEFAULT_KEY, 0},
- {"key_left",&key_left, DEFAULT_KEY, 0},
- {"key_up",&key_up, DEFAULT_KEY, 0},
- {"key_down",&key_down, DEFAULT_KEY, 0},
- {"key_strafeleft",&key_strafeleft, DEFAULT_KEY, 0},
- {"key_straferight",&key_straferight, DEFAULT_KEY, 0},
+ {"key_right",&key_right, DEFAULT_KEY, 0, 0},
+ {"key_left",&key_left, DEFAULT_KEY, 0, 0},
+ {"key_up",&key_up, DEFAULT_KEY, 0, 0},
+ {"key_down",&key_down, DEFAULT_KEY, 0, 0},
+ {"key_strafeleft",&key_strafeleft, DEFAULT_KEY, 0, 0},
+ {"key_straferight",&key_straferight, DEFAULT_KEY, 0, 0},
- {"key_fire",&key_fire, DEFAULT_KEY, 0},
- {"key_use",&key_use, DEFAULT_KEY, 0},
- {"key_strafe",&key_strafe, DEFAULT_KEY, 0},
- {"key_speed",&key_speed, DEFAULT_KEY, 0},
+ {"key_fire",&key_fire, DEFAULT_KEY, 0, 0},
+ {"key_use",&key_use, DEFAULT_KEY, 0, 0},
+ {"key_strafe",&key_strafe, DEFAULT_KEY, 0, 0},
+ {"key_speed",&key_speed, DEFAULT_KEY, 0, 0},
- {"use_mouse",&usemouse, DEFAULT_INT, 0},
- {"mouseb_fire",&mousebfire, DEFAULT_INT, 0},
- {"mouseb_strafe",&mousebstrafe, DEFAULT_INT, 0},
- {"mouseb_forward",&mousebforward, DEFAULT_INT, 0},
+ {"use_mouse",&usemouse, DEFAULT_INT, 0, 0},
+ {"mouseb_fire",&mousebfire, DEFAULT_INT, 0, 0},
+ {"mouseb_strafe",&mousebstrafe, DEFAULT_INT, 0, 0},
+ {"mouseb_forward",&mousebforward, DEFAULT_INT, 0, 0},
- {"use_joystick",&usejoystick, DEFAULT_INT, 0},
- {"joyb_fire",&joybfire, DEFAULT_INT, 0},
- {"joyb_strafe",&joybstrafe, DEFAULT_INT, 0},
- {"joyb_use",&joybuse, DEFAULT_INT, 0},
- {"joyb_speed",&joybspeed, DEFAULT_INT, 0},
+ {"use_joystick",&usejoystick, DEFAULT_INT, 0, 0},
+ {"joyb_fire",&joybfire, DEFAULT_INT, 0, 0},
+ {"joyb_strafe",&joybstrafe, DEFAULT_INT, 0, 0},
+ {"joyb_use",&joybuse, DEFAULT_INT, 0, 0},
+ {"joyb_speed",&joybspeed, DEFAULT_INT, 0, 0},
- {"screenblocks",&screenblocks, DEFAULT_INT, 0},
- {"detaillevel",&detailLevel, DEFAULT_INT, 0},
+ {"screenblocks",&screenblocks, DEFAULT_INT, 0, 0},
+ {"detaillevel",&detailLevel, DEFAULT_INT, 0, 0},
- {"snd_channels",&numChannels, DEFAULT_INT, 0},
+ {"snd_channels",&numChannels, DEFAULT_INT, 0, 0},
- {"snd_musicdevice", &snd_musicdevice, DEFAULT_INT, 0},
- {"snd_sfxdevice", &snd_sfxdevice, DEFAULT_INT, 0},
- {"snd_sbport", &snd_sbport, DEFAULT_INT, 0},
- {"snd_sbirq", &snd_sbirq, DEFAULT_INT, 0},
- {"snd_sbdma", &snd_sbdma, DEFAULT_INT, 0},
- {"snd_mport", &snd_mport, DEFAULT_INT, 0},
+ {"snd_musicdevice", &snd_musicdevice, DEFAULT_INT, 0, 0},
+ {"snd_sfxdevice", &snd_sfxdevice, DEFAULT_INT, 0, 0},
+ {"snd_sbport", &snd_sbport, DEFAULT_INT, 0, 0},
+ {"snd_sbirq", &snd_sbirq, DEFAULT_INT, 0, 0},
+ {"snd_sbdma", &snd_sbdma, DEFAULT_INT, 0, 0},
+ {"snd_mport", &snd_mport, DEFAULT_INT, 0, 0},
- {"usegamma", &usegamma, DEFAULT_INT, 0},
+ {"usegamma", &usegamma, DEFAULT_INT, 0, 0},
{"chatmacro0", &chat_macros[0], DEFAULT_STRING, 0 },
{"chatmacro1", &chat_macros[1], DEFAULT_STRING, 0 },
@@ -331,19 +346,19 @@
static default_t extra_defaults_list[] =
{
- {"autoadjust_video_settings", &autoadjust_video_settings, 0, 0},
- {"fullscreen", &fullscreen, 0, 0},
- {"startup_delay", &startup_delay, 0, 0},
- {"screenmultiply", &screenmultiply, 0, 0},
- {"grabmouse", &grabmouse, 0, 0},
- {"novert", &novert, 0, 0},
- {"mouse_acceleration", &mouse_acceleration, DEFAULT_FLOAT, 0},
- {"mouse_threshold", &mouse_threshold, 0, 0},
- {"show_endoom", &show_endoom, 0, 0},
- {"vanilla_savegame_limit", &vanilla_savegame_limit, 0, 0},
- {"vanilla_demo_limit", &vanilla_demo_limit, 0, 0},
+ {"autoadjust_video_settings", &autoadjust_video_settings, DEFAULT_INT, 0, 0},
+ {"fullscreen", &fullscreen, DEFAULT_INT, 0, 0},
+ {"startup_delay", &startup_delay, DEFAULT_INT, 0, 0},
+ {"screenmultiply", &screenmultiply, DEFAULT_INT, 0, 0},
+ {"grabmouse", &grabmouse, DEFAULT_INT, 0, 0},
+ {"novert", &novert, DEFAULT_INT, 0, 0},
+ {"mouse_acceleration", &mouse_acceleration, DEFAULT_FLOAT, 0, 0},
+ {"mouse_threshold", &mouse_threshold, DEFAULT_INT, 0, 0},
+ {"show_endoom", &show_endoom, DEFAULT_INT, 0, 0},
+ {"vanilla_savegame_limit", &vanilla_savegame_limit, DEFAULT_INT, 0, 0},
+ {"vanilla_demo_limit", &vanilla_demo_limit, DEFAULT_INT, 0, 0},
#ifdef FEATURE_MULTIPLAYER
- {"player_name", &net_player_name, DEFAULT_STRING, 0},
+ {"player_name", &net_player_name, DEFAULT_STRING, 0, 0},
#endif
};
@@ -410,8 +425,12 @@
v = * (int *) defaults[i].location;
- if (defaults[i].untranslated)
+ if (defaults[i].untranslated
+ && v == defaults[i].original_translated)
{
+ // Has not been changed since the last time we
+ // read the config file.
+
v = defaults[i].untranslated;
}
else
@@ -539,6 +558,7 @@
defaults[i].untranslated = intparm;
intparm = scantokey[intparm];
+ defaults[i].original_translated = intparm;
* (int *) def->location = intparm;
break;