mirror of
https://github.com/vcmi/vcmi.git
synced 2025-07-03 00:46:55 +02:00
fix castle replay
This commit is contained in:
@ -282,7 +282,7 @@ void BattleResultProcessor::endBattle(const CBattleInfoCallback & battle)
|
|||||||
// in battles against neutrals attacker can ask to replay battle manually, additionally in battles against AI player human side can also ask for replay
|
// in battles against neutrals attacker can ask to replay battle manually, additionally in battles against AI player human side can also ask for replay
|
||||||
if(onlyOnePlayerHuman)
|
if(onlyOnePlayerHuman)
|
||||||
{
|
{
|
||||||
auto battleDialogQuery = std::make_shared<CBattleDialogQuery>(gameHandler, battle.getBattle());
|
auto battleDialogQuery = std::make_shared<CBattleDialogQuery>(gameHandler, battle.getBattle(), battleQuery->result);
|
||||||
battleResult->queryID = battleDialogQuery->queryID;
|
battleResult->queryID = battleDialogQuery->queryID;
|
||||||
gameHandler->queries->addQuery(battleDialogQuery);
|
gameHandler->queries->addQuery(battleDialogQuery);
|
||||||
}
|
}
|
||||||
|
@ -19,17 +19,10 @@
|
|||||||
#include "../../lib/battle/SideInBattle.h"
|
#include "../../lib/battle/SideInBattle.h"
|
||||||
#include "../../lib/CPlayerState.h"
|
#include "../../lib/CPlayerState.h"
|
||||||
#include "../../lib/mapObjects/CGObjectInstance.h"
|
#include "../../lib/mapObjects/CGObjectInstance.h"
|
||||||
|
#include "../../lib/mapObjects/CGTownInstance.h"
|
||||||
#include "../../lib/networkPacks/PacksForServer.h"
|
#include "../../lib/networkPacks/PacksForServer.h"
|
||||||
#include "../../lib/serializer/Cast.h"
|
#include "../../lib/serializer/Cast.h"
|
||||||
|
|
||||||
void CBattleQuery::notifyObjectAboutRemoval(const CObjectVisitQuery & objectVisit) const
|
|
||||||
{
|
|
||||||
assert(result);
|
|
||||||
|
|
||||||
if(result)
|
|
||||||
objectVisit.visitedObject->battleFinished(objectVisit.visitingHero, *result);
|
|
||||||
}
|
|
||||||
|
|
||||||
CBattleQuery::CBattleQuery(CGameHandler * owner, const IBattleInfo * bi):
|
CBattleQuery::CBattleQuery(CGameHandler * owner, const IBattleInfo * bi):
|
||||||
CQuery(owner),
|
CQuery(owner),
|
||||||
battleID(bi->getBattleID())
|
battleID(bi->getBattleID())
|
||||||
@ -75,9 +68,10 @@ void CBattleQuery::onExposure(QueryPtr topQuery)
|
|||||||
owner->popQuery(*this);
|
owner->popQuery(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
CBattleDialogQuery::CBattleDialogQuery(CGameHandler * owner, const IBattleInfo * bi):
|
CBattleDialogQuery::CBattleDialogQuery(CGameHandler * owner, const IBattleInfo * bi, std::optional<BattleResult> Br):
|
||||||
CDialogQuery(owner),
|
CDialogQuery(owner),
|
||||||
bi(bi)
|
bi(bi),
|
||||||
|
result(Br)
|
||||||
{
|
{
|
||||||
addPlayer(bi->getSidePlayer(0));
|
addPlayer(bi->getSidePlayer(0));
|
||||||
addPlayer(bi->getSidePlayer(1));
|
addPlayer(bi->getSidePlayer(1));
|
||||||
@ -104,6 +98,9 @@ void CBattleDialogQuery::onRemoval(PlayerColor color)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
if(result && bi->getDefendedTown())
|
||||||
|
bi->getDefendedTown()->battleFinished(bi->getSideHero(BattleSide::ATTACKER), *result);
|
||||||
|
|
||||||
gh->battles->endBattleConfirm(bi->getBattleID());
|
gh->battles->endBattleConfirm(bi->getBattleID());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,6 @@ public:
|
|||||||
|
|
||||||
CBattleQuery(CGameHandler * owner);
|
CBattleQuery(CGameHandler * owner);
|
||||||
CBattleQuery(CGameHandler * owner, const IBattleInfo * Bi); //TODO
|
CBattleQuery(CGameHandler * owner, const IBattleInfo * Bi); //TODO
|
||||||
void notifyObjectAboutRemoval(const CObjectVisitQuery &objectVisit) const override;
|
|
||||||
bool blocksPack(const CPack *pack) const override;
|
bool blocksPack(const CPack *pack) const override;
|
||||||
void onRemoval(PlayerColor color) override;
|
void onRemoval(PlayerColor color) override;
|
||||||
void onExposure(QueryPtr topQuery) override;
|
void onExposure(QueryPtr topQuery) override;
|
||||||
@ -37,9 +36,9 @@ public:
|
|||||||
class CBattleDialogQuery : public CDialogQuery
|
class CBattleDialogQuery : public CDialogQuery
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CBattleDialogQuery(CGameHandler * owner, const IBattleInfo * Bi);
|
CBattleDialogQuery(CGameHandler * owner, const IBattleInfo * Bi, std::optional<BattleResult> Br);
|
||||||
|
|
||||||
const IBattleInfo * bi;
|
const IBattleInfo * bi;
|
||||||
|
std::optional<BattleResult> result;
|
||||||
void onRemoval(PlayerColor color) override;
|
void onRemoval(PlayerColor color) override;
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user