mirror of
https://github.com/ZDoom/gzdoom-gles.git
synced 2025-01-18 06:31:45 +00:00
- Fixed: Keys bound in a custom key section would unbind the key in the
main game section. SVN r1409 (trunk)
This commit is contained in:
parent
f867f40bab
commit
8d9bc8cc67
5 changed files with 80 additions and 19 deletions
|
@ -1,5 +1,7 @@
|
||||||
February 6, 2009
|
February 6, 2009
|
||||||
- Fixed scrolling of the automap background on a rotating automap.
|
- Fixed: Keys bound in a custom key section would unbind the key in the
|
||||||
|
main game section.
|
||||||
|
- Fixed scrolling of the automap background on a rotated automap.
|
||||||
|
|
||||||
February 5, 2009
|
February 5, 2009
|
||||||
- Changed singleplayer allowrespawn to act like a co-op game when you
|
- Changed singleplayer allowrespawn to act like a co-op game when you
|
||||||
|
|
|
@ -580,35 +580,61 @@ bool C_DoKey (event_t *ev)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *C_ConfigKeyName(int keynum)
|
||||||
|
{
|
||||||
|
const char *name = KeyName(keynum);
|
||||||
|
if (name[1] == 0) // Make sure given name is config-safe
|
||||||
|
{
|
||||||
|
if (name[0] == '[')
|
||||||
|
return "LeftBracket";
|
||||||
|
else if (name[0] == ']')
|
||||||
|
return "RightBracket";
|
||||||
|
else if (name[0] == '=')
|
||||||
|
return "Equals";
|
||||||
|
else if (strcmp (name, "kp=") == 0)
|
||||||
|
return "KP-Equals";
|
||||||
|
}
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This function is first called for functions in custom key sections.
|
||||||
|
// In this case, matchcmd is non-NULL, and only keys bound to that command
|
||||||
|
// are stored. If a match is found, its binding is set to "\1".
|
||||||
|
// After all custom key sections are saved, it is called one more for the
|
||||||
|
// normal Bindings and DoubleBindings sections for this game. In this case
|
||||||
|
// matchcmd is NULL and all keys will be stored. The config section was not
|
||||||
|
// previously cleared, so all old bindings are still in place. If the binding
|
||||||
|
// for a key is empty, the corresponding key in the config is removed as well.
|
||||||
|
// If a binding is "\1", then the binding itself is cleared, but nothing
|
||||||
|
// happens to the entry in the config.
|
||||||
void C_ArchiveBindings (FConfigFile *f, bool dodouble, const char *matchcmd)
|
void C_ArchiveBindings (FConfigFile *f, bool dodouble, const char *matchcmd)
|
||||||
{
|
{
|
||||||
FString *bindings;
|
FString *bindings;
|
||||||
const char *name;
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
bindings = dodouble ? DoubleBindings : Bindings;
|
bindings = dodouble ? DoubleBindings : Bindings;
|
||||||
|
|
||||||
for (i = 0; i < NUM_KEYS; i++)
|
for (i = 0; i < NUM_KEYS; i++)
|
||||||
{
|
{
|
||||||
if (!bindings[i].IsEmpty() && (matchcmd==NULL || stricmp(bindings[i], matchcmd)==0))
|
if (bindings[i].IsEmpty())
|
||||||
{
|
{
|
||||||
name = KeyName (i);
|
if (matchcmd == NULL)
|
||||||
if (name[1] == 0) // Make sure given name is config-safe
|
|
||||||
{
|
{
|
||||||
if (name[0] == '[')
|
f->ClearKey(C_ConfigKeyName(i));
|
||||||
name = "LeftBracket";
|
|
||||||
else if (name[0] == ']')
|
|
||||||
name = "RightBracket";
|
|
||||||
else if (name[0] == '=')
|
|
||||||
name = "Equals";
|
|
||||||
else if (strcmp (name, "kp=") == 0)
|
|
||||||
name = "KP-Equals";
|
|
||||||
}
|
}
|
||||||
f->SetValueForKey (name, bindings[i]);
|
}
|
||||||
|
else if (matchcmd == NULL || stricmp(bindings[i], matchcmd) == 0)
|
||||||
|
{
|
||||||
|
if (bindings[i][0] == '\1')
|
||||||
|
{
|
||||||
|
bindings[i] = "";
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
f->SetValueForKey(C_ConfigKeyName(i), bindings[i]);
|
||||||
if (matchcmd != NULL)
|
if (matchcmd != NULL)
|
||||||
{ // If saving a specific command, remove the old binding
|
{ // If saving a specific command, set a marker so that
|
||||||
// so it does not get saved in the general binding list
|
// it does not get saved in the general binding list.
|
||||||
Bindings[i] = "";
|
bindings[i] = "\1";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -332,6 +332,40 @@ void FConfigFile::ClearCurrentSection ()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//====================================================================
|
||||||
|
//
|
||||||
|
// FConfigFile :: ClearKey
|
||||||
|
//
|
||||||
|
// Removes a key from the current section, if found. If there are
|
||||||
|
// duplicates, only the first is removed.
|
||||||
|
//
|
||||||
|
//====================================================================
|
||||||
|
|
||||||
|
void FConfigFile::ClearKey(const char *key)
|
||||||
|
{
|
||||||
|
if (CurrentSection->RootEntry == NULL)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
FConfigEntry **prober = &CurrentSection->RootEntry, *probe = *prober;
|
||||||
|
|
||||||
|
while (probe != NULL && stricmp(probe->Key, key) != 0)
|
||||||
|
{
|
||||||
|
prober = &probe->Next;
|
||||||
|
probe = *prober;
|
||||||
|
}
|
||||||
|
if (probe != NULL)
|
||||||
|
{
|
||||||
|
*prober = probe->Next;
|
||||||
|
if (CurrentSection->LastEntryPtr == &probe->Next)
|
||||||
|
{
|
||||||
|
CurrentSection->LastEntryPtr = prober;
|
||||||
|
}
|
||||||
|
delete[] probe->Value;
|
||||||
|
delete[] (char *)probe;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//====================================================================
|
//====================================================================
|
||||||
//
|
//
|
||||||
// FConfigFile :: SectionIsEmpty
|
// FConfigFile :: SectionIsEmpty
|
||||||
|
|
|
@ -59,6 +59,7 @@ public:
|
||||||
bool SetNextSection ();
|
bool SetNextSection ();
|
||||||
const char *GetCurrentSection () const;
|
const char *GetCurrentSection () const;
|
||||||
void ClearCurrentSection ();
|
void ClearCurrentSection ();
|
||||||
|
void ClearKey (const char *key);
|
||||||
|
|
||||||
bool SectionIsEmpty ();
|
bool SectionIsEmpty ();
|
||||||
bool NextInSection (const char *&key, const char *&value);
|
bool NextInSection (const char *&key, const char *&value);
|
||||||
|
|
|
@ -454,12 +454,10 @@ void FGameConfigFile::ArchiveGameData (const char *gamename)
|
||||||
|
|
||||||
strcpy (subsection, "Bindings");
|
strcpy (subsection, "Bindings");
|
||||||
SetSection (section, true);
|
SetSection (section, true);
|
||||||
ClearCurrentSection ();
|
|
||||||
C_ArchiveBindings (this, false);
|
C_ArchiveBindings (this, false);
|
||||||
|
|
||||||
strncpy (subsection, "DoubleBindings", sublen);
|
strncpy (subsection, "DoubleBindings", sublen);
|
||||||
SetSection (section, true);
|
SetSection (section, true);
|
||||||
ClearCurrentSection ();
|
|
||||||
C_ArchiveBindings (this, true);
|
C_ArchiveBindings (this, true);
|
||||||
|
|
||||||
if (WeaponSection.IsEmpty())
|
if (WeaponSection.IsEmpty())
|
||||||
|
|
Loading…
Reference in a new issue