- 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:
Christoph Oelckers 2021-05-12 00:21:26 +02:00
parent 4c161ae403
commit 499ed52972
13 changed files with 104 additions and 20 deletions

View file

@ -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));
} }

View file

@ -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];

View file

@ -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;
} }
} }

View file

@ -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);
} }

View file

@ -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);

View file

@ -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++)
{ {

View file

@ -90,6 +90,7 @@ enum EDemoCommand
DEM_GIVE, DEM_GIVE,
DEM_CHANGEMAP, DEM_CHANGEMAP,
DEM_ENDSCREENJOB, DEM_ENDSCREENJOB,
DEM_SAVEGAME,
DEM_MAX DEM_MAX
}; };

View file

@ -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;

View file

@ -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:

View file

@ -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)

View file

@ -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);

View file

@ -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);
} }

View file

@ -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();