mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
fixed wrong battle result
This commit is contained in:
parent
2fb531b6d0
commit
df13851176
@ -264,13 +264,16 @@ void CHealth::toInfo(CHealthInfo & info) const
|
|||||||
|
|
||||||
void CHealth::takeResurrected()
|
void CHealth::takeResurrected()
|
||||||
{
|
{
|
||||||
int64_t totalHealth = total();
|
if(resurrected != 0)
|
||||||
|
{
|
||||||
|
int64_t totalHealth = available();
|
||||||
|
|
||||||
totalHealth -= resurrected * owner->unitMaxHealth();
|
totalHealth -= resurrected * owner->unitMaxHealth();
|
||||||
vstd::amax(totalHealth, 0);
|
vstd::amax(totalHealth, 0);
|
||||||
setFromTotal(totalHealth);
|
setFromTotal(totalHealth);
|
||||||
resurrected = 0;
|
resurrected = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
///CStack
|
///CStack
|
||||||
CStack::CStack(const CStackInstance * Base, PlayerColor O, int I, ui8 Side, SlotID S):
|
CStack::CStack(const CStackInstance * Base, PlayerColor O, int I, ui8 Side, SlotID S):
|
||||||
|
@ -6429,6 +6429,7 @@ CasualtiesAfterBattle::CasualtiesAfterBattle(const CArmedInstance * _army, Battl
|
|||||||
}
|
}
|
||||||
else if(st->base && !army->slotEmpty(st->slot))
|
else if(st->base && !army->slotEmpty(st->slot))
|
||||||
{
|
{
|
||||||
|
logGlobal->debug("Count: %d; base count: %d", st->getCount(), army->getStackCount(st->slot));
|
||||||
if(st->getCount() == 0 || !st->alive())
|
if(st->getCount() == 0 || !st->alive())
|
||||||
{
|
{
|
||||||
logGlobal->debug("Stack has been destroyed.");
|
logGlobal->debug("Stack has been destroyed.");
|
||||||
|
@ -166,6 +166,18 @@ BOOST_FIXTURE_TEST_CASE(resurrectOneBattle, CUnitHealthInfoMock)
|
|||||||
|
|
||||||
health.init();
|
health.init();
|
||||||
|
|
||||||
|
checkNormalDamage(health, UNIT_HEALTH);
|
||||||
|
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT - 1);
|
||||||
|
BOOST_CHECK_EQUAL(health.getFirstHPleft(), UNIT_HEALTH);
|
||||||
|
BOOST_CHECK_EQUAL(health.getResurrected(), 0);
|
||||||
|
|
||||||
|
health.takeResurrected();
|
||||||
|
BOOST_CHECK_EQUAL(health.getCount(), UNIT_AMOUNT - 1);
|
||||||
|
BOOST_CHECK_EQUAL(health.getFirstHPleft(), UNIT_HEALTH);
|
||||||
|
BOOST_CHECK_EQUAL(health.getResurrected(), 0);
|
||||||
|
|
||||||
|
health.init();
|
||||||
|
|
||||||
checkNormalDamage(health, UNIT_HEALTH * UNIT_AMOUNT);
|
checkNormalDamage(health, UNIT_HEALTH * UNIT_AMOUNT);
|
||||||
checkEmptyHealth(health, *this);
|
checkEmptyHealth(health, *this);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user