mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
- save stuff to the new config.
This commit is contained in:
parent
288b230ab8
commit
f53c9f6947
6 changed files with 93 additions and 35 deletions
|
@ -2211,22 +2211,6 @@ int osdcmd_cvar_set(osdcmdptr_t parm)
|
|||
return OSDCMD_OK;
|
||||
}
|
||||
|
||||
void OSD_WriteAliases(buildvfs_FILE fp)
|
||||
{
|
||||
for (auto &symb : osd->symbptrs)
|
||||
{
|
||||
if (symb == NULL)
|
||||
break;
|
||||
else if (symb->func == (void *)OSD_ALIAS)
|
||||
{
|
||||
buildvfs_fputstr(fp, "alias \"");
|
||||
buildvfs_fputstrptr(fp, symb->name);
|
||||
buildvfs_fputstr(fp, "\" \"");
|
||||
buildvfs_fputstrptr(fp, symb->help);
|
||||
buildvfs_fputstr(fp, "\"\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void OSD_WriteCvars(buildvfs_FILE fp)
|
||||
{
|
||||
|
|
|
@ -658,7 +658,6 @@ void InitBaseRes()
|
|||
}
|
||||
}
|
||||
|
||||
extern FString currentGame;
|
||||
FileReader openFromBaseResource(const char* fn)
|
||||
{
|
||||
InitBaseRes();
|
||||
|
|
|
@ -77,6 +77,12 @@ union UCVarValue
|
|||
int Int;
|
||||
float Float;
|
||||
const char* String;
|
||||
|
||||
UCVarValue() = default;
|
||||
UCVarValue(bool v) { Bool = v; }
|
||||
UCVarValue(int v) { Int = v; }
|
||||
UCVarValue(float v) { Float = v; }
|
||||
UCVarValue(const char * v) { String = v; }
|
||||
};
|
||||
|
||||
enum ECVarType
|
||||
|
|
|
@ -46,6 +46,9 @@
|
|||
//#include "doomstat.h"
|
||||
//#include "gi.h"
|
||||
//#include "d_main.h"
|
||||
#include "keyboard.h"
|
||||
#include "control.h"
|
||||
#include "osd.h"
|
||||
|
||||
#define GAMENAME "Demolition"
|
||||
#define LASTRUNVERSION "1"
|
||||
|
@ -275,15 +278,8 @@ void FGameConfigFile::DoGameSetup (const char *gamename)
|
|||
const char *name = NULL;
|
||||
while (NextInSection (key, value))
|
||||
{
|
||||
if (stricmp (key, "Name") == 0)
|
||||
{
|
||||
name = value;
|
||||
}
|
||||
else if (stricmp (key, "Command") == 0 && name != NULL)
|
||||
{
|
||||
//C_SetAlias (name, value); does not exist yet but will.
|
||||
name = NULL;
|
||||
}
|
||||
FStringf cmd("alias %s \"%s\"", key, value);
|
||||
OSD_Dispatch(cmd);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -308,7 +304,7 @@ void FGameConfigFile::DoKeySetup(const char *gamename)
|
|||
|
||||
//C_SetDefaultBindings ();
|
||||
|
||||
/*
|
||||
#if 0
|
||||
for (int i = 0; binders[i].label != NULL; ++i)
|
||||
{
|
||||
strncpy(subsection, binders[i].label, sublen);
|
||||
|
@ -322,8 +318,25 @@ void FGameConfigFile::DoKeySetup(const char *gamename)
|
|||
}
|
||||
}
|
||||
}
|
||||
#else
|
||||
strncpy(subsection, "Bindings", sublen);
|
||||
if (SetSection(section))
|
||||
{
|
||||
const char* key;
|
||||
const char* value;
|
||||
while (NextInSection(key, value))
|
||||
{
|
||||
// The unbind here is necessary because the Build console can do multiple assignments and would not lose the original binding.
|
||||
FStringf cmd("unbind %s", key);
|
||||
OSD_Dispatch(cmd);
|
||||
|
||||
cmd.Format("bind %s \"%s\"", key, value);
|
||||
OSD_Dispatch(cmd);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
OkayToWrite = true;
|
||||
*/
|
||||
}
|
||||
|
||||
void FGameConfigFile::ReadNetVars ()
|
||||
|
@ -390,6 +403,7 @@ void FGameConfigFile::ArchiveGameData (const char *gamename)
|
|||
ClearCurrentSection ();
|
||||
C_ArchiveCVars (this, CVAR_ARCHIVE|CVAR_AUTO);
|
||||
|
||||
#if 0
|
||||
strncpy (subsection, "ConsoleAliases", sublen);
|
||||
SetSection (section, true);
|
||||
ClearCurrentSection ();
|
||||
|
@ -408,6 +422,31 @@ void FGameConfigFile::ArchiveGameData (const char *gamename)
|
|||
strncpy (subsection, "AutomapBindings", sublen);
|
||||
SetSection (section, true);
|
||||
//AutomapBindings.ArchiveBindings (this);
|
||||
#else
|
||||
strcpy(subsection, "Bindings");
|
||||
if (SetSection(section))
|
||||
{
|
||||
for (int i = 0; i < MAXBOUNDKEYS + MAXMOUSEBUTTONS; i++)
|
||||
{
|
||||
if (CONTROL_KeyIsBound(i))
|
||||
{
|
||||
SetValueForKey(CONTROL_KeyBinds[i].key, CONTROL_KeyBinds[i].cmdstr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
strncpy(subsection, "ConsoleAliases", sublen);
|
||||
if (SetSection(section))
|
||||
{
|
||||
for (auto& symb : osd->symbptrs)
|
||||
{
|
||||
if (symb == NULL)
|
||||
break;
|
||||
|
||||
SetValueForKey(symb->name, symb->help);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void FGameConfigFile::ArchiveGlobalData ()
|
||||
|
@ -495,12 +534,14 @@ void G_LoadConfig(const char* game)
|
|||
GameConfig = new FGameConfigFile();
|
||||
GameConfig->DoGlobalSetup();
|
||||
GameConfig->DoGameSetup(game);
|
||||
GameConfig->DoKeySetup(game);
|
||||
FBaseCVar::EnableCallbacks();
|
||||
GameName = game;
|
||||
}
|
||||
|
||||
void G_SaveConfig()
|
||||
{
|
||||
GameConfig->ArchiveGlobalData();
|
||||
GameConfig->ArchiveGameData(GameName);
|
||||
GameConfig->WriteConfigFile();
|
||||
delete GameConfig;
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
#include "keyboard.h"
|
||||
#include "sc_man.h"
|
||||
#include "c_cvars.h"
|
||||
#include "gameconfigfile.h"
|
||||
#include "build.h"
|
||||
|
||||
struct GameFuncNameDesc
|
||||
|
@ -98,6 +99,8 @@ static const GameFuncNameDesc gamefuncs[] = {
|
|||
|
||||
};
|
||||
|
||||
extern FString currentGame;
|
||||
|
||||
static TMap<FName, int> GF_NameToNum;
|
||||
static FString GF_NumToName[NUMGAMEFUNCTIONS]; // This one will preserve the original name for writing to the config (which must be loaded before CON scripts can hack around with the alias array.)
|
||||
static FString GF_NumToAlias[NUMGAMEFUNCTIONS]; // This is for CON scripts to hack apart.
|
||||
|
@ -120,10 +123,15 @@ static int osdcmd_button(osdcmdptr_t parm)
|
|||
return OSDCMD_OK;
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
//
|
||||
//
|
||||
//==========================================================================
|
||||
|
||||
void SetupButtonFunctions()
|
||||
{
|
||||
unsigned index = 0;
|
||||
// Note: This must run after the CON scripts had a chance to mess around with the game function name array.
|
||||
for (auto& func : GF_NumToAlias)
|
||||
{
|
||||
if (func[0] == '\0')
|
||||
|
@ -133,6 +141,12 @@ void SetupButtonFunctions()
|
|||
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
//
|
||||
//
|
||||
//==========================================================================
|
||||
|
||||
void CONFIG_Init()
|
||||
{
|
||||
// This must be done before initializing any data, so doing it late in the startup process won't work.
|
||||
|
@ -155,10 +169,17 @@ void CONFIG_Init()
|
|||
index += 2;
|
||||
|
||||
}
|
||||
SetupButtonFunctions();
|
||||
CONTROL_ClearAssignments();
|
||||
CONFIG_SetDefaultKeys(cl_defaultconfiguration == 1 ? "demolition/origbinds.txt" : cl_defaultconfiguration == 2 ? "demolition/leftbinds.txt" : "demolition/defbinds.txt");
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
//
|
||||
//
|
||||
//==========================================================================
|
||||
|
||||
int32_t CONFIG_FunctionNameToNum(const char *func)
|
||||
{
|
||||
if (!func) return -1;
|
||||
|
@ -201,7 +222,12 @@ void CONFIG_DeleteButtonName(int num)
|
|||
GF_NumToAlias[num] = "";
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
// wrapper for CONTROL_MapKey(), generates key bindings to reflect changes to keyboard setup
|
||||
//
|
||||
//==========================================================================
|
||||
|
||||
void CONFIG_MapKey(int which, kb_scancode key1, kb_scancode oldkey1, kb_scancode key2, kb_scancode oldkey2)
|
||||
{
|
||||
int const keys[] = { key1, key2, oldkey1, oldkey2 };
|
||||
|
@ -246,6 +272,12 @@ void CONFIG_MapKey(int which, kb_scancode key1, kb_scancode oldkey1, kb_scancode
|
|||
}
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
//
|
||||
//
|
||||
//==========================================================================
|
||||
|
||||
void CONFIG_SetDefaultKeys(const char *defbinds, bool lazy/*=false*/)
|
||||
{
|
||||
FScanner sc;
|
||||
|
@ -304,3 +336,4 @@ void CONFIG_SetDefaultKeys(const char *defbinds, bool lazy/*=false*/)
|
|||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -473,8 +473,6 @@ long FileWriter::Seek(long offset, int mode)
|
|||
|
||||
size_t FileWriter::Printf(const char *fmt, ...)
|
||||
{
|
||||
// fix me later
|
||||
#if 0
|
||||
va_list ap;
|
||||
FString out;
|
||||
|
||||
|
@ -482,9 +480,6 @@ size_t FileWriter::Printf(const char *fmt, ...)
|
|||
out.VFormat(fmt, ap);
|
||||
va_end(ap);
|
||||
return Write(out.GetChars(), out.Len());
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
size_t BufferWriter::Write(const void *buffer, size_t len)
|
||||
|
|
Loading…
Reference in a new issue