mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
Merge pull request #2308 from IvanSavenko/remove_client_savegame
Remove client savegames
This commit is contained in:
commit
280085b95d
@ -761,7 +761,7 @@ void CServerHandler::debugStartTest(std::string filename, bool save)
|
||||
if(save)
|
||||
{
|
||||
resetStateForLobby(StartInfo::LOAD_GAME);
|
||||
mapInfo->saveInit(ResourceID(filename, EResType::CLIENT_SAVEGAME));
|
||||
mapInfo->saveInit(ResourceID(filename, EResType::SAVEGAME));
|
||||
screenType = ESelectionScreen::loadGame;
|
||||
}
|
||||
else
|
||||
|
@ -94,7 +94,6 @@ public:
|
||||
void visitSystemMessage(SystemMessage & pack) override;
|
||||
void visitPlayerBlocked(PlayerBlocked & pack) override;
|
||||
void visitYourTurn(YourTurn & pack) override;
|
||||
void visitSaveGameClient(SaveGameClient & pack) override;
|
||||
void visitPlayerMessageClient(PlayerMessageClient & pack) override;
|
||||
void visitAdvmapSpellCast(AdvmapSpellCast & pack) override;
|
||||
void visitShowWorldViewEx(ShowWorldViewEx & pack) override;
|
||||
|
@ -856,26 +856,6 @@ void ApplyClientNetPackVisitor::visitYourTurn(YourTurn & pack)
|
||||
callOnlyThatInterface(cl, pack.player, &CGameInterface::yourTurn);
|
||||
}
|
||||
|
||||
void ApplyClientNetPackVisitor::visitSaveGameClient(SaveGameClient & pack)
|
||||
{
|
||||
const auto stem = FileInfo::GetPathStem(pack.fname);
|
||||
if(!CResourceHandler::get("local")->createResource(stem.to_string() + ".vcgm1"))
|
||||
{
|
||||
logNetwork->error("Failed to create resource %s", stem.to_string() + ".vcgm1");
|
||||
return;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
CSaveFile save(*CResourceHandler::get()->getResourceName(ResourceID(stem.to_string(), EResType::CLIENT_SAVEGAME)));
|
||||
save << cl;
|
||||
}
|
||||
catch(std::exception &e)
|
||||
{
|
||||
logNetwork->error("Failed to save game:%s", e.what());
|
||||
}
|
||||
}
|
||||
|
||||
void ApplyClientNetPackVisitor::visitPlayerMessageClient(PlayerMessageClient & pack)
|
||||
{
|
||||
logNetwork->debug("pack.player %s sends a message: %s", pack.player.getStr(), pack.text);
|
||||
|
@ -80,7 +80,7 @@ void CSavingScreen::saveGame()
|
||||
close();
|
||||
};
|
||||
|
||||
if(CResourceHandler::get("local")->existsResource(ResourceID(path, EResType::CLIENT_SAVEGAME)))
|
||||
if(CResourceHandler::get("local")->existsResource(ResourceID(path, EResType::SAVEGAME)))
|
||||
{
|
||||
std::string hlp = CGI->generaltexth->allTexts[493]; //%s exists. Overwrite?
|
||||
boost::algorithm::replace_first(hlp, "%s", tabSel->inputName->getText());
|
||||
|
@ -232,11 +232,11 @@ void SelectionTab::toggleMode()
|
||||
|
||||
case ESelectionScreen::loadGame:
|
||||
inputName->disable();
|
||||
parseSaves(getFiles("Saves/", EResType::SERVER_SAVEGAME));
|
||||
parseSaves(getFiles("Saves/", EResType::SAVEGAME));
|
||||
break;
|
||||
|
||||
case ESelectionScreen::saveGame:
|
||||
parseSaves(getFiles("Saves/", EResType::SERVER_SAVEGAME));
|
||||
parseSaves(getFiles("Saves/", EResType::SAVEGAME));
|
||||
inputName->enable();
|
||||
restoreLastSelection();
|
||||
break;
|
||||
@ -414,7 +414,7 @@ void SelectionTab::select(int position)
|
||||
|
||||
if(inputName && inputName->isActive())
|
||||
{
|
||||
auto filename = *CResourceHandler::get("local")->getResourceName(ResourceID(curItems[py]->fileURI, EResType::CLIENT_SAVEGAME));
|
||||
auto filename = *CResourceHandler::get("local")->getResourceName(ResourceID(curItems[py]->fileURI, EResType::SAVEGAME));
|
||||
inputName->setText(filename.stem().string());
|
||||
}
|
||||
|
||||
|
@ -138,7 +138,6 @@ public:
|
||||
virtual void visitDigWithHero(DigWithHero & pack) {}
|
||||
virtual void visitCastAdvSpell(CastAdvSpell & pack) {}
|
||||
virtual void visitSaveGame(SaveGame & pack) {}
|
||||
virtual void visitSaveGameClient(SaveGameClient & pack) {}
|
||||
virtual void visitPlayerMessage(PlayerMessage & pack) {}
|
||||
virtual void visitPlayerMessageClient(PlayerMessageClient & pack) {}
|
||||
virtual void visitCenterView(CenterView & pack) {}
|
||||
|
@ -2585,23 +2585,6 @@ struct DLL_LINKAGE SaveGame : public CPackForServer
|
||||
}
|
||||
};
|
||||
|
||||
// TODO: Eventually we should re-merge both SaveGame and PlayerMessage
|
||||
struct DLL_LINKAGE SaveGameClient : public CPackForClient
|
||||
{
|
||||
SaveGameClient() = default;
|
||||
SaveGameClient(std::string Fname)
|
||||
: fname(std::move(Fname))
|
||||
{
|
||||
}
|
||||
std::string fname;
|
||||
virtual void visitTyped(ICPackVisitor & visitor) override;
|
||||
|
||||
template <typename Handler> void serialize(Handler & h, const int version)
|
||||
{
|
||||
h & fname;
|
||||
}
|
||||
};
|
||||
|
||||
struct DLL_LINKAGE PlayerMessage : public CPackForServer
|
||||
{
|
||||
PlayerMessage() = default;
|
||||
|
@ -657,11 +657,6 @@ void SaveGame::visitTyped(ICPackVisitor & visitor)
|
||||
visitor.visitSaveGame(*this);
|
||||
}
|
||||
|
||||
void SaveGameClient::visitTyped(ICPackVisitor & visitor)
|
||||
{
|
||||
visitor.visitSaveGameClient(*this);
|
||||
}
|
||||
|
||||
void PlayerMessage::visitTyped(ICPackVisitor & visitor)
|
||||
{
|
||||
visitor.visitPlayerMessage(*this);
|
||||
|
@ -153,8 +153,7 @@ EResType::Type EResTypeHelper::getTypeFromExtension(std::string extension)
|
||||
{".VID", EResType::ARCHIVE_VID},
|
||||
{".SND", EResType::ARCHIVE_SND},
|
||||
{".PAL", EResType::PALETTE},
|
||||
{".VCGM1", EResType::CLIENT_SAVEGAME},
|
||||
{".VSGM1", EResType::SERVER_SAVEGAME},
|
||||
{".VSGM1", EResType::SAVEGAME},
|
||||
{".ERM", EResType::ERM},
|
||||
{".ERT", EResType::ERT},
|
||||
{".ERS", EResType::ERS},
|
||||
@ -191,8 +190,7 @@ std::string EResTypeHelper::getEResTypeAsString(EResType::Type type)
|
||||
MAP_ENUM(ARCHIVE_SND)
|
||||
MAP_ENUM(ARCHIVE_VID)
|
||||
MAP_ENUM(PALETTE)
|
||||
MAP_ENUM(CLIENT_SAVEGAME)
|
||||
MAP_ENUM(SERVER_SAVEGAME)
|
||||
MAP_ENUM(SAVEGAME)
|
||||
MAP_ENUM(DIRECTORY)
|
||||
MAP_ENUM(ERM)
|
||||
MAP_ENUM(ERT)
|
||||
|
@ -50,8 +50,7 @@ namespace EResType
|
||||
ARCHIVE_SND,
|
||||
ARCHIVE_LOD,
|
||||
PALETTE,
|
||||
CLIENT_SAVEGAME,
|
||||
SERVER_SAVEGAME,
|
||||
SAVEGAME,
|
||||
DIRECTORY,
|
||||
ERM,
|
||||
ERT,
|
||||
|
@ -326,7 +326,6 @@ void registerTypesClientPacks2(Serializer &s)
|
||||
s.template registerType<CArtifactOperationPack, DisassembledArtifact>();
|
||||
s.template registerType<CArtifactOperationPack, BulkMoveArtifacts>();
|
||||
|
||||
s.template registerType<CPackForClient, SaveGameClient>();
|
||||
s.template registerType<CPackForClient, PlayerMessageClient>();
|
||||
s.template registerType<CGarrisonOperationPack, BulkRebalanceStacks>();
|
||||
s.template registerType<CGarrisonOperationPack, BulkSmartRebalanceStacks>();
|
||||
|
@ -2909,16 +2909,10 @@ void CGameHandler::save(const std::string & filename)
|
||||
const auto savefname = stem.to_string() + ".vsgm1";
|
||||
CResourceHandler::get("local")->createResource(savefname);
|
||||
|
||||
{
|
||||
logGlobal->info("Ordering clients to serialize...");
|
||||
SaveGameClient sg(savefname);
|
||||
sendToAllClients(&sg);
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
{
|
||||
CSaveFile save(*CResourceHandler::get("local")->getResourceName(ResourceID(stem.to_string(), EResType::SERVER_SAVEGAME)));
|
||||
CSaveFile save(*CResourceHandler::get("local")->getResourceName(ResourceID(stem.to_string(), EResType::SAVEGAME)));
|
||||
saveCommonState(save);
|
||||
logGlobal->info("Saving server state");
|
||||
save << *this;
|
||||
@ -2941,7 +2935,7 @@ bool CGameHandler::load(const std::string & filename)
|
||||
try
|
||||
{
|
||||
{
|
||||
CLoadFile lf(*CResourceHandler::get("local")->getResourceName(ResourceID(stem.to_string(), EResType::SERVER_SAVEGAME)), MINIMAL_SERIALIZATION_VERSION);
|
||||
CLoadFile lf(*CResourceHandler::get("local")->getResourceName(ResourceID(stem.to_string(), EResType::SAVEGAME)), MINIMAL_SERIALIZATION_VERSION);
|
||||
loadCommonState(lf);
|
||||
logGlobal->info("Loading server state");
|
||||
lf >> *this;
|
||||
|
Loading…
Reference in New Issue
Block a user