mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-14 03:40:50 +00:00
- route savegame requests through the newwork, just like GZDoom does.
Although a bit overkill for single player saves only, this will ensure consistent behavior between both engines regarding the menu.
This commit is contained in:
parent
4c161ae403
commit
499ed52972
13 changed files with 104 additions and 20 deletions
|
@ -293,8 +293,8 @@ CCMD (md5sum)
|
||||||
}
|
}
|
||||||
for (int i = 1; i < argv.argc(); ++i)
|
for (int i = 1; i < argv.argc(); ++i)
|
||||||
{
|
{
|
||||||
FileReader fr = fileSystem.OpenFileReader(argv[i]);
|
FileReader fr;
|
||||||
if (!fr.isOpen())
|
if (!fr.OpenFile(argv[i]))
|
||||||
{
|
{
|
||||||
Printf("%s: %s\n", argv[i], strerror(errno));
|
Printf("%s: %s\n", argv[i], strerror(errno));
|
||||||
}
|
}
|
||||||
|
|
|
@ -232,7 +232,6 @@ DEFINE_ACTION_FUNCTION(FSavegameManager, LoadSavegame)
|
||||||
|
|
||||||
void FSavegameManagerBase::DoSave(int Selected, const char *savegamestring)
|
void FSavegameManagerBase::DoSave(int Selected, const char *savegamestring)
|
||||||
{
|
{
|
||||||
RemoveNewSaveNode();
|
|
||||||
if (Selected != 0)
|
if (Selected != 0)
|
||||||
{
|
{
|
||||||
auto node = SaveGames[Selected];
|
auto node = SaveGames[Selected];
|
||||||
|
|
|
@ -449,13 +449,14 @@ DFrameBuffer *SDLVideo::CreateFrameBuffer ()
|
||||||
device = new VulkanDevice();
|
device = new VulkanDevice();
|
||||||
fb = new VulkanFrameBuffer(nullptr, vid_fullscreen, device);
|
fb = new VulkanFrameBuffer(nullptr, vid_fullscreen, device);
|
||||||
}
|
}
|
||||||
catch (CVulkanError const&)
|
catch (CVulkanError const &error)
|
||||||
{
|
{
|
||||||
if (Priv::window != nullptr)
|
if (Priv::window != nullptr)
|
||||||
{
|
{
|
||||||
Priv::DestroyWindow();
|
Priv::DestroyWindow();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Printf(TEXTCOLOR_RED "Initialization of Vulkan failed: %s\n", error.what());
|
||||||
Priv::vulkanEnabled = false;
|
Priv::vulkanEnabled = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -594,7 +594,7 @@ void DStatusBarCore::DrawGraphic(FGameTexture* tex, double x, double y, int flag
|
||||||
DTA_FillColor, (flags & DI_ALPHAMAPPED) ? 0 : -1,
|
DTA_FillColor, (flags & DI_ALPHAMAPPED) ? 0 : -1,
|
||||||
DTA_FlipX, !!(flags & DI_MIRROR),
|
DTA_FlipX, !!(flags & DI_MIRROR),
|
||||||
DTA_FlipY, !!(flags& DI_MIRRORY),
|
DTA_FlipY, !!(flags& DI_MIRRORY),
|
||||||
DTA_LegacyRenderStyle, style,
|
DTA_LegacyRenderStyle, (flags & DI_ALPHAMAPPED) ? STYLE_Shaded : style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,3 +9,4 @@ EXTERN_CVAR(Bool, sv_cheats)
|
||||||
void genericCheat(int player, uint8_t** stream, bool skip);
|
void genericCheat(int player, uint8_t** stream, bool skip);
|
||||||
void changeMap(int player, uint8_t** stream, bool skip);
|
void changeMap(int player, uint8_t** stream, bool skip);
|
||||||
void endScreenJob(int player, uint8_t** stream, bool skip);
|
void endScreenJob(int player, uint8_t** stream, bool skip);
|
||||||
|
void startSaveGame(int player, uint8_t** stream, bool skip);
|
||||||
|
|
|
@ -1674,6 +1674,7 @@ bool D_CheckNetGame (void)
|
||||||
Net_SetCommandHandler(DEM_GENERICCHEAT, genericCheat);
|
Net_SetCommandHandler(DEM_GENERICCHEAT, genericCheat);
|
||||||
Net_SetCommandHandler(DEM_CHANGEMAP, changeMap);
|
Net_SetCommandHandler(DEM_CHANGEMAP, changeMap);
|
||||||
Net_SetCommandHandler(DEM_ENDSCREENJOB, endScreenJob);
|
Net_SetCommandHandler(DEM_ENDSCREENJOB, endScreenJob);
|
||||||
|
Net_SetCommandHandler(DEM_SAVEGAME, startSaveGame);
|
||||||
|
|
||||||
for (i = 0; i < MAXNETNODES; i++)
|
for (i = 0; i < MAXNETNODES; i++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -90,6 +90,7 @@ enum EDemoCommand
|
||||||
DEM_GIVE,
|
DEM_GIVE,
|
||||||
DEM_CHANGEMAP,
|
DEM_CHANGEMAP,
|
||||||
DEM_ENDSCREENJOB,
|
DEM_ENDSCREENJOB,
|
||||||
|
DEM_SAVEGAME,
|
||||||
|
|
||||||
DEM_MAX
|
DEM_MAX
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,6 +12,10 @@
|
||||||
#include "i_time.h"
|
#include "i_time.h"
|
||||||
#include "palentry.h"
|
#include "palentry.h"
|
||||||
|
|
||||||
|
extern bool sendsave;
|
||||||
|
extern FString savedescription;
|
||||||
|
extern FString savegamefile;
|
||||||
|
|
||||||
extern FString currentGame;
|
extern FString currentGame;
|
||||||
extern FString LumpFilter;
|
extern FString LumpFilter;
|
||||||
extern int PlayClock;
|
extern int PlayClock;
|
||||||
|
|
|
@ -110,6 +110,9 @@ FString BackupSaveGame;
|
||||||
|
|
||||||
void DoLoadGame(const char* name);
|
void DoLoadGame(const char* name);
|
||||||
|
|
||||||
|
bool sendsave;
|
||||||
|
FString savedescription;
|
||||||
|
FString savegamefile;
|
||||||
|
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
//
|
//
|
||||||
|
@ -119,6 +122,14 @@ void DoLoadGame(const char* name);
|
||||||
|
|
||||||
void G_BuildTiccmd(ticcmd_t* cmd)
|
void G_BuildTiccmd(ticcmd_t* cmd)
|
||||||
{
|
{
|
||||||
|
if (sendsave)
|
||||||
|
{
|
||||||
|
sendsave = false;
|
||||||
|
Net_WriteByte(DEM_SAVEGAME);
|
||||||
|
Net_WriteString(savegamefile);
|
||||||
|
Net_WriteString(savedescription);
|
||||||
|
savegamefile = "";
|
||||||
|
}
|
||||||
cmd->ucmd = {};
|
cmd->ucmd = {};
|
||||||
I_GetEvent();
|
I_GetEvent();
|
||||||
auto input = CONTROL_GetInput();
|
auto input = CONTROL_GetInput();
|
||||||
|
@ -240,8 +251,10 @@ static void GameTicker()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ga_savegame:
|
case ga_savegame:
|
||||||
// We only need this for multiplayer saves that need to go through the network.
|
G_DoSaveGame(true, false, savegamefile, savedescription);
|
||||||
// gi->SaveGame();
|
gameaction = ga_nothing;
|
||||||
|
savegamefile = "";
|
||||||
|
savedescription = "";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ga_autosave:
|
case ga_autosave:
|
||||||
|
|
|
@ -119,7 +119,7 @@ void FSavegameManager::PerformLoadGame(const char *f, bool s)
|
||||||
|
|
||||||
void FSavegameManager::PerformSaveGame(const char *f, const char *s)
|
void FSavegameManager::PerformSaveGame(const char *f, const char *s)
|
||||||
{
|
{
|
||||||
G_SaveGame(f, s, true, false);
|
G_SaveGame(f, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
FString FSavegameManager::BuildSaveName(const char* fn, int slot)
|
FString FSavegameManager::BuildSaveName(const char* fn, int slot)
|
||||||
|
|
|
@ -309,7 +309,7 @@ CCMD(quicksave)
|
||||||
// [mxd]. Just save the game, no questions asked.
|
// [mxd]. Just save the game, no questions asked.
|
||||||
if (!saveloadconfirmation)
|
if (!saveloadconfirmation)
|
||||||
{
|
{
|
||||||
G_SaveGame(savegameManager.quickSaveSlot->Filename, savegameManager.quickSaveSlot->SaveTitle, true, true);
|
G_SaveGame(savegameManager.quickSaveSlot->Filename, savegameManager.quickSaveSlot->SaveTitle);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -320,7 +320,7 @@ CCMD(quicksave)
|
||||||
DMenu* newmenu = CreateMessageBoxMenu(CurrentMenu, tempstring, 0, false, NAME_None, []()
|
DMenu* newmenu = CreateMessageBoxMenu(CurrentMenu, tempstring, 0, false, NAME_None, []()
|
||||||
{
|
{
|
||||||
M_ClearMenus();
|
M_ClearMenus();
|
||||||
G_SaveGame(savegameManager.quickSaveSlot->Filename, savegameManager.quickSaveSlot->SaveTitle, true, true);
|
G_SaveGame(savegameManager.quickSaveSlot->Filename, savegameManager.quickSaveSlot->SaveTitle);
|
||||||
});
|
});
|
||||||
|
|
||||||
M_ActivateMenu(newmenu);
|
M_ActivateMenu(newmenu);
|
||||||
|
|
|
@ -69,6 +69,7 @@ walltype wallbackup[MAXWALLS];
|
||||||
void WriteSavePic(FileWriter* file, int width, int height);
|
void WriteSavePic(FileWriter* file, int width, int height);
|
||||||
bool WriteZip(const char* filename, TArray<FString>& filenames, TArray<FCompressedBuffer>& content);
|
bool WriteZip(const char* filename, TArray<FString>& filenames, TArray<FCompressedBuffer>& content);
|
||||||
extern FString BackupSaveGame;
|
extern FString BackupSaveGame;
|
||||||
|
|
||||||
void SerializeMap(FSerializer &arc);
|
void SerializeMap(FSerializer &arc);
|
||||||
FixedBitArray<MAXSPRITES> activeSprites;
|
FixedBitArray<MAXSPRITES> activeSprites;
|
||||||
|
|
||||||
|
@ -694,18 +695,80 @@ static int nextquicksave = -1;
|
||||||
BackupSaveGame = filename;
|
BackupSaveGame = filename;
|
||||||
}
|
}
|
||||||
|
|
||||||
void G_SaveGame(const char *fn, const char *desc, bool ok4q, bool forceq)
|
extern bool sendsave;
|
||||||
|
extern FString savedescription;
|
||||||
|
extern FString savegamefile;
|
||||||
|
|
||||||
|
void G_SaveGame(const char* filename, const char* description)
|
||||||
|
{
|
||||||
|
if (sendsave || gameaction == ga_savegame)
|
||||||
|
{
|
||||||
|
Printf("%s\n", GStrings("TXT_SAVEPENDING"));
|
||||||
|
}
|
||||||
|
else if (gamestate != GS_LEVEL)
|
||||||
|
{
|
||||||
|
Printf("%s\n", GStrings("TXT_NOTINLEVEL"));
|
||||||
|
}
|
||||||
|
else if (!gi->CanSave())
|
||||||
|
{
|
||||||
|
Printf("%s\n", GStrings("TXT_SPPLAYERDEAD"));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
savegamefile = filename;
|
||||||
|
savedescription = description;
|
||||||
|
sendsave = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void startSaveGame(int player, uint8_t** stream, bool skip)
|
||||||
|
{
|
||||||
|
auto s = ReadString(stream);
|
||||||
|
savegamefile = s;
|
||||||
|
delete[] s;
|
||||||
|
s = ReadString(stream);
|
||||||
|
savedescription = s;
|
||||||
|
if (!skip && gi->CanSave())
|
||||||
|
{
|
||||||
|
if (player != consoleplayer)
|
||||||
|
{
|
||||||
|
// Paths sent over the network will be valid for the system that sent
|
||||||
|
// the save command. For other systems, the path needs to be changed.
|
||||||
|
savegamefile = G_BuildSaveName(ExtractFileBase(savegamefile, true));
|
||||||
|
}
|
||||||
|
gameaction = ga_savegame;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void G_DoSaveGame(bool ok4q, bool forceq, const char* fn, const char* desc)
|
||||||
{
|
{
|
||||||
if (WriteSavegame(fn, desc))
|
if (WriteSavegame(fn, desc))
|
||||||
{
|
{
|
||||||
savegameManager.NotifyNewSave(fn, desc, ok4q, forceq);
|
savegameManager.NotifyNewSave(fn, desc, ok4q, forceq);
|
||||||
Printf(PRINT_NOTIFY, "%s\n", GStrings("GAME SAVED"));
|
Printf(PRINT_NOTIFY, "%s\n", GStrings("GGSAVED"));
|
||||||
BackupSaveGame = fn;
|
BackupSaveGame = fn;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void M_Autosave()
|
void M_Autosave()
|
||||||
{
|
{
|
||||||
if (disableautosave) return;
|
if (disableautosave) return;
|
||||||
if (!gi->CanSave()) return;
|
if (!gi->CanSave()) return;
|
||||||
|
@ -728,7 +791,7 @@ void M_Autosave()
|
||||||
readableTime = myasctime();
|
readableTime = myasctime();
|
||||||
FStringf SaveTitle("Autosave %s", readableTime);
|
FStringf SaveTitle("Autosave %s", readableTime);
|
||||||
nextautosave = (nextautosave + 1) % count;
|
nextautosave = (nextautosave + 1) % count;
|
||||||
G_SaveGame(Filename, SaveTitle, false, false);
|
G_DoSaveGame(false, false, Filename, SaveTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
CCMD(autosave)
|
CCMD(autosave)
|
||||||
|
@ -759,7 +822,7 @@ CCMD(rotatingquicksave)
|
||||||
readableTime = myasctime();
|
readableTime = myasctime();
|
||||||
FStringf SaveTitle("Quicksave %s", readableTime);
|
FStringf SaveTitle("Quicksave %s", readableTime);
|
||||||
nextquicksave = (nextquicksave + 1) % count;
|
nextquicksave = (nextquicksave + 1) % count;
|
||||||
G_SaveGame(Filename, SaveTitle, false, false);
|
G_SaveGame(Filename, SaveTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,8 @@ FString G_BuildSaveName (const char *prefix);
|
||||||
int G_ValidateSavegame(FileReader &fr, FString *savetitle, bool formenu);
|
int G_ValidateSavegame(FileReader &fr, FString *savetitle, bool formenu);
|
||||||
|
|
||||||
void G_LoadGame(const char* filename);
|
void G_LoadGame(const char* filename);
|
||||||
void G_SaveGame(const char* fn, const char* desc, bool ok4q, bool forceq);
|
void G_SaveGame(const char* fn, const char* desc);
|
||||||
|
void G_DoSaveGame(bool okForQuicksave, bool forceQuicksave, const char* filename, const char* description);
|
||||||
|
|
||||||
void M_Autosave();
|
void M_Autosave();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue