From b472c892769a817e277ba84a4d111147e038c476 Mon Sep 17 00:00:00 2001 From: Konstantin P Date: Thu, 27 Apr 2023 20:43:20 +0300 Subject: [PATCH] vcmi: make some CStack properties private There is a getters for this properties already available --- AI/BattleAI/BattleAI.cpp | 6 +- AI/BattleAI/BattleAI.h | 2 +- AI/BattleAI/ThreatMap.cpp | 2 +- AI/StupidAI/StupidAI.cpp | 4 +- client/CPlayerInterface.cpp | 2 +- client/NetPacksClient.cpp | 4 +- client/battle/BattleActionsController.cpp | 2 +- client/battle/BattleAnimationClasses.cpp | 8 +- client/battle/BattleFieldController.cpp | 10 +- client/battle/BattleInterface.cpp | 4 +- client/battle/BattleInterfaceClasses.cpp | 8 +- client/battle/BattleProjectileController.cpp | 10 +- client/battle/BattleStacksController.cpp | 86 +++++++-------- client/windows/CCreatureWindow.cpp | 2 +- lib/CGameInterface.cpp | 2 +- lib/CStack.cpp | 2 +- lib/CStack.h | 11 +- lib/HeroBonus.cpp | 4 +- lib/NetPacksLib.cpp | 2 +- lib/battle/BattleInfo.cpp | 5 +- lib/battle/CBattleInfoCallback.cpp | 6 +- lib/battle/CBattleInfoEssentials.cpp | 4 +- lib/battle/CPlayerBattleCallback.cpp | 4 +- lib/spells/BattleSpellMechanics.cpp | 4 +- server/CGameHandler.cpp | 108 +++++++++---------- 25 files changed, 152 insertions(+), 150 deletions(-) diff --git a/AI/BattleAI/BattleAI.cpp b/AI/BattleAI/BattleAI.cpp index f9824c70c..2073b0a58 100644 --- a/AI/BattleAI/BattleAI.cpp +++ b/AI/BattleAI/BattleAI.cpp @@ -102,7 +102,7 @@ BattleAction CBattleAI::activeStack( const CStack * stack ) try { - if(stack->type->getId() == CreatureID::CATAPULT) + if(stack->creatureId() == CreatureID::CATAPULT) return useCatapult(stack); if(stack->hasBonusOfType(Bonus::SIEGE_WEAPON) && stack->hasBonusOfType(Bonus::HEALER)) { @@ -420,7 +420,7 @@ BattleAction CBattleAI::useCatapult(const CStack * stack) attack.aimToHex(targetHex); attack.actionType = EActionType::CATAPULT; attack.side = side; - attack.stackNumber = stack->ID; + attack.stackNumber = stack->unitId(); movesSkippedByDefense = 0; @@ -815,7 +815,7 @@ std::optional CBattleAI::considerFleeingOrSurrendering() { if(stack->alive()) { - if(stack->side == bs.ourSide) + if(stack->unitSide() == bs.ourSide) bs.ourStacks.push_back(stack); else { diff --git a/AI/BattleAI/BattleAI.h b/AI/BattleAI/BattleAI.h index f9a877206..5da4fc01d 100644 --- a/AI/BattleAI/BattleAI.h +++ b/AI/BattleAI/BattleAI.h @@ -31,7 +31,7 @@ struct CurrentOffensivePotential { for(auto stack : cbc->battleGetStacks()) { - if(stack->side == side) + if(stack->unitSide() == side) ourAttacks[stack] = PotentialTargets(stack); else enemyAttacks[stack] = PotentialTargets(stack); diff --git a/AI/BattleAI/ThreatMap.cpp b/AI/BattleAI/ThreatMap.cpp index eb44da728..5b3bab584 100644 --- a/AI/BattleAI/ThreatMap.cpp +++ b/AI/BattleAI/ThreatMap.cpp @@ -30,7 +30,7 @@ ThreatMap::ThreatMap(const CStack *Endangered) : endangered(Endangered) for(const CStack *enemy : getCbc()->battleGetStacks()) { //Consider only stacks of different owner - if(enemy->side == endangered->side) + if(enemy->unitSide() == endangered->unitSide()) continue; //Look-up which tiles can be melee-attacked diff --git a/AI/StupidAI/StupidAI.cpp b/AI/StupidAI/StupidAI.cpp index 0a66edefc..35dce8c1d 100644 --- a/AI/StupidAI/StupidAI.cpp +++ b/AI/StupidAI/StupidAI.cpp @@ -95,7 +95,7 @@ BattleAction CStupidAI::activeStack( const CStack * stack ) ReachabilityInfo dists = cb->getReachability(stack); std::vector enemiesShootable, enemiesReachable, enemiesUnreachable; - if(stack->type->getId() == CreatureID::CATAPULT) + if(stack->creatureId() == CreatureID::CATAPULT) { BattleAction attack; static const std::vector wallHexes = {50, 183, 182, 130, 78, 29, 12, 95}; @@ -103,7 +103,7 @@ BattleAction CStupidAI::activeStack( const CStack * stack ) attack.aimToHex(seletectedHex); attack.actionType = EActionType::CATAPULT; attack.side = side; - attack.stackNumber = stack->ID; + attack.stackNumber = stack->unitId(); return attack; } diff --git a/client/CPlayerInterface.cpp b/client/CPlayerInterface.cpp index dc1bc2d6f..e84fe4dbc 100644 --- a/client/CPlayerInterface.cpp +++ b/client/CPlayerInterface.cpp @@ -774,7 +774,7 @@ BattleAction CPlayerInterface::activeStack(const CStack * stack) //called when i { THREAD_CREATED_BY_CLIENT; logGlobal->trace("Awaiting command for %s", stack->nodeName()); - auto stackId = stack->ID; + auto stackId = stack->unitId(); auto stackName = stack->nodeName(); if (autofightingAI) { diff --git a/client/NetPacksClient.cpp b/client/NetPacksClient.cpp index e2f4313ad..5aa8db87d 100644 --- a/client/NetPacksClient.cpp +++ b/client/NetPacksClient.cpp @@ -708,13 +708,13 @@ void ApplyClientNetPackVisitor::visitBattleSetActiveStack(BattleSetActiveStack & PlayerColor playerToCall; //pack.player that will move activated stack if (activated->hasBonusOfType(Bonus::HYPNOTIZED)) { - playerToCall = (gs.curB->sides[0].color == activated->owner + playerToCall = (gs.curB->sides[0].color == activated->unitOwner() ? gs.curB->sides[1].color : gs.curB->sides[0].color); } else { - playerToCall = activated->owner; + playerToCall = activated->unitOwner(); } cl.startPlayerBattleAction(playerToCall); diff --git a/client/battle/BattleActionsController.cpp b/client/battle/BattleActionsController.cpp index 256b897fd..f05d554fc 100644 --- a/client/battle/BattleActionsController.cpp +++ b/client/battle/BattleActionsController.cpp @@ -524,7 +524,7 @@ std::string BattleActionsController::actionGetStatusMessageBlocked(PossiblePlaye bool BattleActionsController::actionIsLegal(PossiblePlayerBattleAction action, BattleHex targetHex) { const CStack * targetStack = getStackForHex(targetHex); - bool targetStackOwned = targetStack && targetStack->owner == owner.curInt->playerID; + bool targetStackOwned = targetStack && targetStack->unitOwner() == owner.curInt->playerID; switch (action.get()) { diff --git a/client/battle/BattleAnimationClasses.cpp b/client/battle/BattleAnimationClasses.cpp index 1c58e6011..d6b3ad9df 100644 --- a/client/battle/BattleAnimationClasses.cpp +++ b/client/battle/BattleAnimationClasses.cpp @@ -71,17 +71,17 @@ std::vector & BattleAnimation::pendingAnimations() std::shared_ptr BattleAnimation::stackAnimation(const CStack * stack) const { - return owner.stacksController->stackAnimation[stack->ID]; + return owner.stacksController->stackAnimation[stack->unitId()]; } bool BattleAnimation::stackFacingRight(const CStack * stack) { - return owner.stacksController->stackFacingRight[stack->ID]; + return owner.stacksController->stackFacingRight[stack->unitId()]; } void BattleAnimation::setStackFacingRight(const CStack * stack, bool facingRight) { - owner.stacksController->stackFacingRight[stack->ID] = facingRight; + owner.stacksController->stackFacingRight[stack->unitId()] = facingRight; } BattleStackAnimation::BattleStackAnimation(BattleInterface & owner, const CStack * stack) @@ -279,7 +279,7 @@ ECreatureAnimType MeleeAttackAnimation::selectGroup(bool multiAttack) getForwardGroup (multiAttack) }; - int revShiftattacker = (attackingStack->side == BattleSide::ATTACKER ? -1 : 1); + int revShiftattacker = (attackingStack->unitSide() == BattleSide::ATTACKER ? -1 : 1); int mutPos = BattleHex::mutualPosition(attackingStackPosBeforeReturn, dest); if(mutPos == -1 && attackingStack->doubleWide()) diff --git a/client/battle/BattleFieldController.cpp b/client/battle/BattleFieldController.cpp index 4ebc2d93d..beed22812 100644 --- a/client/battle/BattleFieldController.cpp +++ b/client/battle/BattleFieldController.cpp @@ -134,7 +134,7 @@ void BattleFieldController::renderBattlefield(Canvas & canvas) void BattleFieldController::showBackground(Canvas & canvas) { - if (owner.stacksController->getActiveStack() != nullptr ) //&& creAnims[stacksController->getActiveStack()->ID]->isIdle() //show everything with range + if (owner.stacksController->getActiveStack() != nullptr ) //&& creAnims[stacksController->getActiveStack()->unitId()]->isIdle() //show everything with range showBackgroundImageWithHexes(canvas); else showBackgroundImage(canvas); @@ -540,7 +540,7 @@ BattleHex BattleFieldController::fromWhichHexAttack(BattleHex attackTarget) case BattleHex::LEFT: case BattleHex::BOTTOM_LEFT: { - if ( attacker->side == BattleSide::ATTACKER ) + if ( attacker->unitSide() == BattleSide::ATTACKER ) return attackTarget.cloneInDirection(direction); else return attackTarget.cloneInDirection(direction).cloneInDirection(BattleHex::LEFT); @@ -550,7 +550,7 @@ BattleHex BattleFieldController::fromWhichHexAttack(BattleHex attackTarget) case BattleHex::RIGHT: case BattleHex::BOTTOM_RIGHT: { - if ( attacker->side == BattleSide::ATTACKER ) + if ( attacker->unitSide() == BattleSide::ATTACKER ) return attackTarget.cloneInDirection(direction).cloneInDirection(BattleHex::RIGHT); else return attackTarget.cloneInDirection(direction); @@ -558,7 +558,7 @@ BattleHex BattleFieldController::fromWhichHexAttack(BattleHex attackTarget) case BattleHex::TOP: { - if ( attacker->side == BattleSide::ATTACKER ) + if ( attacker->unitSide() == BattleSide::ATTACKER ) return attackTarget.cloneInDirection(BattleHex::TOP_RIGHT); else return attackTarget.cloneInDirection(BattleHex::TOP_LEFT); @@ -566,7 +566,7 @@ BattleHex BattleFieldController::fromWhichHexAttack(BattleHex attackTarget) case BattleHex::BOTTOM: { - if ( attacker->side == BattleSide::ATTACKER ) + if ( attacker->unitSide() == BattleSide::ATTACKER ) return attackTarget.cloneInDirection(BattleHex::BOTTOM_RIGHT); else return attackTarget.cloneInDirection(BattleHex::BOTTOM_LEFT); diff --git a/client/battle/BattleInterface.cpp b/client/battle/BattleInterface.cpp index 62d5dd9fe..6a819e25c 100644 --- a/client/battle/BattleInterface.cpp +++ b/client/battle/BattleInterface.cpp @@ -208,7 +208,7 @@ void BattleInterface::stacksAreAttacked(std::vector attackedI for(const StackAttackedInfo & attackedInfo : attackedInfos) { - ui8 side = attackedInfo.defender->side; + ui8 side = attackedInfo.defender->unitSide(); killedBySide.at(side) += attackedInfo.amountKilled; } @@ -288,7 +288,7 @@ const CGHeroInstance * BattleInterface::getActiveHero() return nullptr; } - if(attacker->side == BattleSide::ATTACKER) + if(attacker->unitSide() == BattleSide::ATTACKER) { return attackingHeroInstance; } diff --git a/client/battle/BattleInterfaceClasses.cpp b/client/battle/BattleInterfaceClasses.cpp index ebdff1507..ae17c4eed 100644 --- a/client/battle/BattleInterfaceClasses.cpp +++ b/client/battle/BattleInterfaceClasses.cpp @@ -455,18 +455,18 @@ BattleResultWindow::BattleResultWindow(const BattleResult & br, CPlayerInterface auto stacks = owner.cb->battleGetAllStacks(); vstd::erase_if(stacks, [i](const CStack * stack) //erase stack of other side and not coming from garrison { - return stack->side != i || !stack->base; + return stack->unitSide() != i || !stack->base; }); auto best = vstd::maxElementByFun(stacks, [](const CStack * stack) { - return stack->type->getAIValue(); + return stack->unitType()->getAIValue(); }); if(best != stacks.end()) //should be always but to be safe... { - icons.push_back(std::make_shared("TWCRPORT", (*best)->type->getIconIndex(), 0, xs[i], 38)); - sideNames[i] = (*best)->type->getNamePluralTranslated(); + icons.push_back(std::make_shared("TWCRPORT", (*best)->unitType()->getIconIndex(), 0, xs[i], 38)); + sideNames[i] = (*best)->unitType()->getNamePluralTranslated(); } } } diff --git a/client/battle/BattleProjectileController.cpp b/client/battle/BattleProjectileController.cpp index b291f9756..a52060661 100644 --- a/client/battle/BattleProjectileController.cpp +++ b/client/battle/BattleProjectileController.cpp @@ -205,7 +205,7 @@ std::shared_ptr BattleProjectileController::getProjectileImage(const void BattleProjectileController::emitStackProjectile(const CStack * stack) { - int stackID = stack ? stack->ID : -1; + int stackID = stack ? stack->unitId() : -1; for (auto projectile : projectiles) { @@ -232,7 +232,7 @@ void BattleProjectileController::showProjectiles(Canvas & canvas) bool BattleProjectileController::hasActiveProjectile(const CStack * stack, bool emittedOnly) const { - int stackID = stack ? stack->ID : -1; + int stackID = stack ? stack->unitId() : -1; for(auto const & instance : projectiles) { @@ -294,7 +294,7 @@ void BattleProjectileController::createCatapultProjectile(const CStack * shooter catapultProjectile->speed = computeProjectileFlightTime(from, dest, AnimationControls::getCatapultSpeed()); catapultProjectile->from = from; catapultProjectile->dest = dest; - catapultProjectile->shooterID = shooter->ID; + catapultProjectile->shooterID = shooter->unitId(); catapultProjectile->playing = false; catapultProjectile->frameProgress = 0.f; @@ -333,7 +333,7 @@ void BattleProjectileController::createProjectile(const CStack * shooter, Point projectile->from = from; projectile->dest = dest; - projectile->shooterID = shooter->ID; + projectile->shooterID = shooter->unitId(); projectile->progress = 0; projectile->playing = false; @@ -357,7 +357,7 @@ void BattleProjectileController::createSpellProjectile(const CStack * shooter, P projectile->reverse = from.x > dest.x; projectile->from = from; projectile->dest = dest; - projectile->shooterID = shooter ? shooter->ID : -1; + projectile->shooterID = shooter ? shooter->unitId() : -1; projectile->progress = 0; projectile->speed = computeProjectileFlightTime(from, dest, AnimationControls::getProjectileSpeed()); projectile->playing = false; diff --git a/client/battle/BattleStacksController.cpp b/client/battle/BattleStacksController.cpp index 9a224e965..413a5bb21 100644 --- a/client/battle/BattleStacksController.cpp +++ b/client/battle/BattleStacksController.cpp @@ -104,10 +104,10 @@ BattleStacksController::BattleStacksController(BattleInterface & owner): BattleHex BattleStacksController::getStackCurrentPosition(const CStack * stack) const { - if ( !stackAnimation.at(stack->ID)->isMoving()) + if ( !stackAnimation.at(stack->unitId())->isMoving()) return stack->getPosition(); - if (stack->hasBonusOfType(Bonus::FLYING) && stackAnimation.at(stack->ID)->getType() == ECreatureAnimType::MOVING ) + if (stack->hasBonusOfType(Bonus::FLYING) && stackAnimation.at(stack->unitId())->getType() == ECreatureAnimType::MOVING ) return BattleHex::HEX_AFTER_ALL; for (auto & anim : currentAnimations) @@ -131,14 +131,14 @@ void BattleStacksController::collectRenderableObjects(BattleRenderer & renderer) for (auto stack : stacks) { - if (stackAnimation.find(stack->ID) == stackAnimation.end()) //e.g. for summoned but not yet handled stacks + if (stackAnimation.find(stack->unitId()) == stackAnimation.end()) //e.g. for summoned but not yet handled stacks continue; //FIXME: hack to ignore ghost stacks - if ((stackAnimation[stack->ID]->getType() == ECreatureAnimType::DEAD || stackAnimation[stack->ID]->getType() == ECreatureAnimType::HOLDING) && stack->isGhost()) + if ((stackAnimation[stack->unitId()]->getType() == ECreatureAnimType::DEAD || stackAnimation[stack->unitId()]->getType() == ECreatureAnimType::HOLDING) && stack->isGhost()) continue; - auto layer = stackAnimation[stack->ID]->isDead() ? EBattleFieldLayer::CORPSES : EBattleFieldLayer::STACKS; + auto layer = stackAnimation[stack->unitId()]->isDead() ? EBattleFieldLayer::CORPSES : EBattleFieldLayer::STACKS; auto location = getStackCurrentPosition(stack); renderer.insert(layer, location, [this, stack]( BattleRenderer::RendererRef renderer ){ @@ -159,13 +159,13 @@ void BattleStacksController::stackReset(const CStack * stack) owner.checkForAnimations(); //reset orientation? - //stackFacingRight[stack->ID] = stack->side == BattleSide::ATTACKER; + //stackFacingRight[stack->unitId()] = stack->unitSide() == BattleSide::ATTACKER; - auto iter = stackAnimation.find(stack->ID); + auto iter = stackAnimation.find(stack->unitId()); if(iter == stackAnimation.end()) { - logGlobal->error("Unit %d have no animation", stack->ID); + logGlobal->error("Unit %d have no animation", stack->unitId()); return; } @@ -185,7 +185,7 @@ void BattleStacksController::stackAdded(const CStack * stack, bool instant) // Tower shooters have only their upper half visible static const int turretCreatureAnimationHeight = 232; - stackFacingRight[stack->ID] = stack->side == BattleSide::ATTACKER; // must be set before getting stack position + stackFacingRight[stack->unitId()] = stack->unitSide() == BattleSide::ATTACKER; // must be set before getting stack position Point coords = getStackPositionAtHex(stack->getPosition(), stack); @@ -195,26 +195,26 @@ void BattleStacksController::stackAdded(const CStack * stack, bool instant) const CCreature *turretCreature = owner.siegeController->getTurretCreature(); - stackAnimation[stack->ID] = AnimationControls::getAnimation(turretCreature); - stackAnimation[stack->ID]->pos.h = turretCreatureAnimationHeight; - stackAnimation[stack->ID]->pos.w = stackAnimation[stack->ID]->getWidth(); + stackAnimation[stack->unitId()] = AnimationControls::getAnimation(turretCreature); + stackAnimation[stack->unitId()]->pos.h = turretCreatureAnimationHeight; + stackAnimation[stack->unitId()]->pos.w = stackAnimation[stack->unitId()]->getWidth(); // FIXME: workaround for visible animation of Medusa tails (animation disabled in H3) if (turretCreature->getId() == CreatureID::MEDUSA ) - stackAnimation[stack->ID]->pos.w = 250; + stackAnimation[stack->unitId()]->pos.w = 250; coords = owner.siegeController->getTurretCreaturePosition(stack->initialPosition); } else { - stackAnimation[stack->ID] = AnimationControls::getAnimation(stack->unitType()); - stackAnimation[stack->ID]->onAnimationReset += std::bind(&onAnimationFinished, stack, stackAnimation[stack->ID]); - stackAnimation[stack->ID]->pos.h = stackAnimation[stack->ID]->getHeight(); - stackAnimation[stack->ID]->pos.w = stackAnimation[stack->ID]->getWidth(); + stackAnimation[stack->unitId()] = AnimationControls::getAnimation(stack->unitType()); + stackAnimation[stack->unitId()]->onAnimationReset += std::bind(&onAnimationFinished, stack, stackAnimation[stack->unitId()]); + stackAnimation[stack->unitId()]->pos.h = stackAnimation[stack->unitId()]->getHeight(); + stackAnimation[stack->unitId()]->pos.w = stackAnimation[stack->unitId()]->getWidth(); } - stackAnimation[stack->ID]->pos.x = coords.x; - stackAnimation[stack->ID]->pos.y = coords.y; - stackAnimation[stack->ID]->setType(ECreatureAnimType::HOLDING); + stackAnimation[stack->unitId()]->pos.x = coords.x; + stackAnimation[stack->unitId()]->pos.y = coords.y; + stackAnimation[stack->unitId()]->setType(ECreatureAnimType::HOLDING); if (!instant) { @@ -234,12 +234,12 @@ void BattleStacksController::stackAdded(const CStack * stack, bool instant) void BattleStacksController::setActiveStack(const CStack *stack) { if (activeStack) // update UI - stackAnimation[activeStack->ID]->setBorderColor(AnimationControls::getNoBorder()); + stackAnimation[activeStack->unitId()]->setBorderColor(AnimationControls::getNoBorder()); activeStack = stack; if (activeStack) // update UI - stackAnimation[activeStack->ID]->setBorderColor(AnimationControls::getGoldBorder()); + stackAnimation[activeStack->unitId()]->setBorderColor(AnimationControls::getGoldBorder()); owner.windowObject->blockUI(activeStack == nullptr); } @@ -258,7 +258,7 @@ bool BattleStacksController::stackNeedsAmountBox(const CStack * stack) const return false; // if stack has any ongoing animation - hide the box - if (stackAmountBoxHidden.count(stack->ID)) + if (stackAmountBoxHidden.count(stack->unitId())) return false; return true; @@ -291,7 +291,7 @@ void BattleStacksController::showStackAmountBox(Canvas & canvas, const CStack * bool doubleWide = stack->doubleWide(); bool turnedRight = facingRight(stack); - bool attacker = stack->side == BattleSide::ATTACKER; + bool attacker = stack->unitSide() == BattleSide::ATTACKER; BattleHex stackPos = stack->getPosition(); @@ -334,8 +334,8 @@ void BattleStacksController::showStack(Canvas & canvas, const CStack * stack) fullFilter = ColorFilter::genCombined(fullFilter, filter.effect); } - stackAnimation[stack->ID]->nextFrame(canvas, fullFilter, facingRight(stack)); // do actual blit - stackAnimation[stack->ID]->incrementFrame(float(GH.mainFPSmng->getElapsedMilliseconds()) / 1000); + stackAnimation[stack->unitId()]->nextFrame(canvas, fullFilter, facingRight(stack)); // do actual blit + stackAnimation[stack->unitId()]->incrementFrame(float(GH.mainFPSmng->getElapsedMilliseconds()) / 1000); } void BattleStacksController::update() @@ -390,17 +390,17 @@ void BattleStacksController::addNewAnim(BattleAnimation *anim) auto stackAnimation = dynamic_cast(anim); if(stackAnimation) - stackAmountBoxHidden.insert(stackAnimation->stack->ID); + stackAmountBoxHidden.insert(stackAnimation->stack->unitId()); } void BattleStacksController::stackRemoved(uint32_t stackID) { - if (getActiveStack() && getActiveStack()->ID == stackID) + if (getActiveStack() && getActiveStack()->unitId() == stackID) { BattleAction *action = new BattleAction(); action->side = owner.defendingHeroInstance ? (owner.curInt->playerID == owner.defendingHeroInstance->tempOwner) : false; action->actionType = EActionType::CANCEL; - action->stackNumber = getActiveStack()->ID; + action->stackNumber = getActiveStack()->unitId(); owner.givenCommand.setn(action); setActiveStack(nullptr); } @@ -431,7 +431,7 @@ void BattleStacksController::stacksAreAttacked(std::vector at // FIXME: this check is better, however not usable since stacksAreAttacked is called after net pack is applyed - petrification is already removed // if (needsReverse && !attackedInfo.defender->isFrozen()) - if (needsReverse && stackAnimation[attackedInfo.defender->ID]->getType() != ECreatureAnimType::FROZEN) + if (needsReverse && stackAnimation[attackedInfo.defender->unitId()]->getType() != ECreatureAnimType::FROZEN) { owner.addToAnimationStage(EAnimationEvents::MOVEMENT, [=]() { @@ -485,7 +485,7 @@ void BattleStacksController::stacksAreAttacked(std::vector at { owner.addToAnimationStage(EAnimationEvents::AFTER_HIT, [=](){ addNewAnim(new ColorTransformAnimation(owner, attackedInfo.defender, "summonFadeOut", nullptr)); - stackRemoved(attackedInfo.defender->ID); + stackRemoved(attackedInfo.defender->unitId()); }); } } @@ -503,7 +503,7 @@ void BattleStacksController::stackTeleported(const CStack *stack, std::vectorID]->pos.moveTo(getStackPositionAtHex(destHex.back(), stack)); + stackAnimation[stack->unitId()]->pos.moveTo(getStackPositionAtHex(destHex.back(), stack)); addNewAnim( new ColorTransformAnimation(owner, stack, "teleportFadeIn", nullptr) ); }); @@ -551,7 +551,7 @@ bool BattleStacksController::shouldAttackFacingRight(const CStack * attacker, co attacker, defender); - if (attacker->side == BattleSide::ATTACKER) + if (attacker->unitSide() == BattleSide::ATTACKER) return !mustReverse; else return mustReverse; @@ -669,9 +669,9 @@ void BattleStacksController::endAction(const BattleAction* action) for (const CStack *s : stacks) { - bool shouldFaceRight = s && s->side == BattleSide::ATTACKER; + bool shouldFaceRight = s && s->unitSide() == BattleSide::ATTACKER; - if (s && facingRight(s) != shouldFaceRight && s->alive() && stackAnimation[s->ID]->isIdle()) + if (s && facingRight(s) != shouldFaceRight && s->alive() && stackAnimation[s->unitId()]->isIdle()) { addNewAnim(new ReverseAnimation(owner, s, s->getPosition())); } @@ -715,7 +715,7 @@ void BattleStacksController::activateStack() if ( !stackToActivate) return; - owner.trySetActivePlayer(stackToActivate->owner); + owner.trySetActivePlayer(stackToActivate->unitOwner()); setActiveStack(stackToActivate); stackToActivate = nullptr; @@ -732,7 +732,7 @@ const CStack* BattleStacksController::getActiveStack() const bool BattleStacksController::facingRight(const CStack * stack) const { - return stackFacingRight.at(stack->ID); + return stackFacingRight.at(stack->unitId()); } Point BattleStacksController::getStackPositionAtHex(BattleHex hexNum, const CStack * stack) const @@ -757,7 +757,7 @@ Point BattleStacksController::getStackPositionAtHex(BattleHex hexNum, const CSta //shifting position for double - hex creatures if(stack->doubleWide()) { - if(stack->side == BattleSide::ATTACKER) + if(stack->unitSide() == BattleSide::ATTACKER) { if(facingRight(stack)) ret.x -= 44; @@ -812,9 +812,9 @@ void BattleStacksController::updateHoveredStacks() continue; if (stack == activeStack) - stackAnimation[stack->ID]->setBorderColor(AnimationControls::getGoldBorder()); + stackAnimation[stack->unitId()]->setBorderColor(AnimationControls::getGoldBorder()); else - stackAnimation[stack->ID]->setBorderColor(AnimationControls::getNoBorder()); + stackAnimation[stack->unitId()]->setBorderColor(AnimationControls::getNoBorder()); } for(const auto * stack : newStacks) @@ -822,9 +822,9 @@ void BattleStacksController::updateHoveredStacks() if (vstd::contains(mouseHoveredStacks, stack)) continue; - stackAnimation[stack->ID]->setBorderColor(AnimationControls::getBlueBorder()); - if (stackAnimation[stack->ID]->framesInGroup(ECreatureAnimType::MOUSEON) > 0 && stack->alive() && !stack->isFrozen()) - stackAnimation[stack->ID]->playOnce(ECreatureAnimType::MOUSEON); + stackAnimation[stack->unitId()]->setBorderColor(AnimationControls::getBlueBorder()); + if (stackAnimation[stack->unitId()]->framesInGroup(ECreatureAnimType::MOUSEON) > 0 && stack->alive() && !stack->isFrozen()) + stackAnimation[stack->unitId()]->playOnce(ECreatureAnimType::MOUSEON); } mouseHoveredStacks = newStacks; diff --git a/client/windows/CCreatureWindow.cpp b/client/windows/CCreatureWindow.cpp index 1ef1f9672..40a166ea0 100644 --- a/client/windows/CCreatureWindow.cpp +++ b/client/windows/CCreatureWindow.cpp @@ -651,7 +651,7 @@ CStackWindow::CStackWindow(const CStack * stack, bool popup) { info->stack = stack; info->stackNode = stack->base; - info->creature = stack->type; + info->creature = stack->unitType(); info->creatureCount = stack->getCount(); info->popupWindow = popup; init(); diff --git a/lib/CGameInterface.cpp b/lib/CGameInterface.cpp index 8f0018d23..f558edbe6 100644 --- a/lib/CGameInterface.cpp +++ b/lib/CGameInterface.cpp @@ -156,7 +156,7 @@ BattleAction CGlobalAI::activeStack(const CStack * stack) { BattleAction ba; ba.actionType = EActionType::DEFEND; - ba.stackNumber = stack->ID; + ba.stackNumber = stack->unitId(); return ba; } diff --git a/lib/CStack.cpp b/lib/CStack.cpp index e06a66d06..966481790 100644 --- a/lib/CStack.cpp +++ b/lib/CStack.cpp @@ -28,7 +28,7 @@ CStack::CStack(const CStackInstance * Base, const PlayerColor & O, int I, ui8 Si base(Base), ID(I), type(Base->type), - baseAmount(base->count), + baseAmount(Base->count), owner(O), slot(S), side(Side) diff --git a/lib/CStack.h b/lib/CStack.h index 6c6912e39..920bf2d47 100644 --- a/lib/CStack.h +++ b/lib/CStack.h @@ -25,17 +25,20 @@ class BattleInfo; //Represents STACK_BATTLE nodes class DLL_LINKAGE CStack : public CBonusSystemNode, public battle::CUnitState, public battle::IUnitEnvironment { -public: - const CStackInstance * base = nullptr; //garrison slot from which stack originates (nullptr for war machines, summoned cres, etc) - +private: ui32 ID = -1; //unique ID of stack const CCreature * type = nullptr; TerrainId nativeTerrain; //tmp variable to save native terrain value on battle init ui32 baseAmount = -1; PlayerColor owner; //owner - player color (255 for neutrals) - SlotID slot; //slot - position in garrison (may be 255 for neutrals/called creatures) ui8 side = 1; + + SlotID slot; //slot - position in garrison (may be 255 for neutrals/called creatures) + +public: + const CStackInstance * base = nullptr; //garrison slot from which stack originates (nullptr for war machines, summoned cres, etc) + BattleHex initialPosition; //position on battlefield; -2 - keep, -3 - lower tower, -4 - upper tower CStack(const CStackInstance * base, const PlayerColor & O, int I, ui8 Side, const SlotID & S); diff --git a/lib/HeroBonus.cpp b/lib/HeroBonus.cpp index c789d5487..266d91b9d 100644 --- a/lib/HeroBonus.cpp +++ b/lib/HeroBonus.cpp @@ -2047,7 +2047,7 @@ const CCreature * retrieveCreature(const CBonusSystemNode *node) case CBonusSystemNode::CREATURE: return (dynamic_cast(node)); case CBonusSystemNode::STACK_BATTLE: - return (dynamic_cast(node))->type; + return (dynamic_cast(node))->unitType(); default: const CStackInstance * csi = retrieveStackInstance(node); if(csi) @@ -2749,7 +2749,7 @@ std::shared_ptr TimesStackLevelUpdater::createUpdatedBonus(const std::sha //otherwise we'd end up multiplying twice if(stack.base == nullptr) { - int level = stack.type->getLevel(); + int level = stack.unitType()->getLevel(); std::shared_ptr newBonus = std::make_shared(*b); newBonus->val *= level; return newBonus; diff --git a/lib/NetPacksLib.cpp b/lib/NetPacksLib.cpp index 7df87426e..0e22bb872 100644 --- a/lib/NetPacksLib.cpp +++ b/lib/NetPacksLib.cpp @@ -2467,7 +2467,7 @@ void BattleSetStackProperty::applyGs(CGameState * gs) const } case ENCHANTER_COUNTER: { - auto & counter = gs->curB->sides[gs->curB->whatSide(stack->owner)].enchanterCounter; + auto & counter = gs->curB->sides[gs->curB->whatSide(stack->unitOwner())].enchanterCounter; if(absolute) counter = val; else diff --git a/lib/battle/BattleInfo.cpp b/lib/battle/BattleInfo.cpp index 259f9b691..3cbe219a1 100644 --- a/lib/battle/BattleInfo.cpp +++ b/lib/battle/BattleInfo.cpp @@ -47,12 +47,11 @@ std::pair< std::vector, int > BattleInfo::getPath(BattleHex start, Ba void BattleInfo::calculateCasualties(std::map * casualties) const { - for(const auto & elem : stacks) //setting casualties + for(const auto & st : stacks) //setting casualties { - const CStack * const st = elem; si32 killed = st->getKilled(); if(killed > 0) - casualties[st->side][st->unitType()->getId()] += killed; + casualties[st->unitSide()][st->creatureId()] += killed; } } diff --git a/lib/battle/CBattleInfoCallback.cpp b/lib/battle/CBattleInfoCallback.cpp index a1d2c0f75..7a1a651d6 100644 --- a/lib/battle/CBattleInfoCallback.cpp +++ b/lib/battle/CBattleInfoCallback.cpp @@ -1367,7 +1367,7 @@ std::set CBattleInfoCallback::getAttackedCreatures(const CStack* for (BattleHex tile : at.hostileCreaturePositions) //all around & three-headed attack { const CStack * st = battleGetStackByPos(tile, true); - if(st && st->owner != attacker->owner) //only hostile stacks - does it work well with Berserk? + if(st && st->unitOwner() != attacker->unitOwner()) //only hostile stacks - does it work well with Berserk? { attackedCres.insert(st); } @@ -1623,7 +1623,7 @@ SpellID CBattleInfoCallback::getRandomBeneficialSpell(CRandomGenerator & rand, c { auto stacks = battleGetStacksIf([=](const CStack * stack) { - return pred(stack) && stack->owner != subject->owner && stack->isValidTarget(false); + return pred(stack) && stack->unitOwner() != subject->unitOwner() && stack->isValidTarget(false); }); if(stacks.empty()) @@ -1673,7 +1673,7 @@ SpellID CBattleInfoCallback::getRandomBeneficialSpell(CRandomGenerator & rand, c case SpellID::PROTECTION_FROM_FIRE: case SpellID::PROTECTION_FROM_WATER: { - const ui8 enemySide = 1 - subject->side; + const ui8 enemySide = 1 - subject->unitSide(); //todo: only if enemy has spellbook if (!battleHasHero(enemySide)) //only if there is enemy hero continue; diff --git a/lib/battle/CBattleInfoEssentials.cpp b/lib/battle/CBattleInfoEssentials.cpp index 912b3e6c8..38177183b 100644 --- a/lib/battle/CBattleInfoEssentials.cpp +++ b/lib/battle/CBattleInfoEssentials.cpp @@ -87,7 +87,7 @@ bool CBattleInfoEssentials::battleHasNativeStack(ui8 side) const for(const auto * s : battleGetAllStacks()) { - if(s->side == side && s->isNativeTerrain(getBattle()->getTerrainType())) + if(s->unitSide() == side && s->isNativeTerrain(getBattle()->getTerrainType())) return true; } @@ -173,7 +173,7 @@ const CStack* CBattleInfoEssentials::battleGetStackByID(int ID, bool onlyAlive) auto stacks = battleGetStacksIf([=](const CStack * s) { - return s->ID == ID && (!onlyAlive || s->alive()); + return s->unitId() == ID && (!onlyAlive || s->alive()); }); if(stacks.empty()) diff --git a/lib/battle/CPlayerBattleCallback.cpp b/lib/battle/CPlayerBattleCallback.cpp index abdc631ed..f8b555c19 100644 --- a/lib/battle/CPlayerBattleCallback.cpp +++ b/lib/battle/CPlayerBattleCallback.cpp @@ -30,8 +30,8 @@ TStacks CPlayerBattleCallback::battleGetStacks(EStackOwnership whose, bool onlyA return battleGetStacksIf([=](const CStack * s){ const bool ownerMatches = (whose == MINE_AND_ENEMY) - || (whose == ONLY_MINE && s->owner == player) - || (whose == ONLY_ENEMY && s->owner != player); + || (whose == ONLY_MINE && s->unitOwner() == player) + || (whose == ONLY_ENEMY && s->unitOwner() != player); return ownerMatches && s->isValidTarget(!onlyAlive); }); diff --git a/lib/spells/BattleSpellMechanics.cpp b/lib/spells/BattleSpellMechanics.cpp index b243c6b3c..e1fadc88a 100644 --- a/lib/spells/BattleSpellMechanics.cpp +++ b/lib/spells/BattleSpellMechanics.cpp @@ -279,9 +279,9 @@ void BattleSpellMechanics::cast(ServerCallback * server, const Target & target) if(nullptr != otherHero) //handle mana channel { int manaChannel = 0; - for(const CStack * stack : battle()->battleGetAllStacks(true)) //TODO: shouldn't bonus system handle it somehow? + for(const auto * stack : battle()->battleGetAllStacks(true)) //TODO: shouldn't bonus system handle it somehow? { - if(stack->owner == otherHero->tempOwner) + if(stack->unitOwner() == otherHero->tempOwner) { vstd::amax(manaChannel, stack->valOfBonuses(Bonus::MANA_CHANNELING)); } diff --git a/server/CGameHandler.cpp b/server/CGameHandler.cpp index 8132e1b6c..a8b0d9469 100644 --- a/server/CGameHandler.cpp +++ b/server/CGameHandler.cpp @@ -951,7 +951,7 @@ void CGameHandler::makeAttack(const CStack * attacker, const CStack * defender, bat.flags |= BattleAttack::DEATH_BLOW; } - const auto * owner = gs->curB->getHero(attacker->owner); + const auto * owner = gs->curB->getHero(attacker->unitOwner()); if(owner) { int chance = owner->valOfBonuses(Bonus::BONUS_DAMAGE_CHANCE, attacker->creatureIndex()); @@ -1005,7 +1005,7 @@ void CGameHandler::makeAttack(const CStack * attacker, const CStack * defender, //now add effect info for all attacked stacks for (BattleStackAttacked & bsa : bat.bsa) { - if (bsa.attackerID == attacker->ID) //this is our attack and not f.e. fire shield + if (bsa.attackerID == attacker->unitId()) //this is our attack and not f.e. fire shield { //this is need for displaying affect animation bsa.flags |= BattleStackAttacked::SPELL_EFFECT; @@ -1072,7 +1072,7 @@ void CGameHandler::makeAttack(const CStack * attacker, const CStack * defender, const CStack * actor = item.first; int64_t rawDamage = item.second; - const CGHeroInstance * actorOwner = gs->curB->getHero(actor->owner); + const CGHeroInstance * actorOwner = gs->curB->getHero(actor->unitOwner()); if(actorOwner) { @@ -1092,8 +1092,8 @@ void CGameHandler::makeAttack(const CStack * attacker, const CStack * defender, BattleStackAttacked bsa; bsa.flags |= BattleStackAttacked::FIRE_SHIELD; - bsa.stackAttacked = attacker->ID; //invert - bsa.attackerID = defender->ID; + bsa.stackAttacked = attacker->unitId(); //invert + bsa.attackerID = defender->unitId(); bsa.damageAmount = totalDamage; attacker->prepareAttacked(bsa, getRandomGenerator()); @@ -1323,7 +1323,7 @@ int CGameHandler::moveStack(int stack, BattleHex dest) bool canUseGate = false; auto dbState = gs->curB->si.gateState; - if(battleGetSiegeLevel() > 0 && curStack->side == BattleSide::DEFENDER && + if(battleGetSiegeLevel() > 0 && curStack->unitSide() == BattleSide::DEFENDER && dbState != EGateState::DESTROYED && dbState != EGateState::BLOCKED) { @@ -1385,7 +1385,7 @@ int CGameHandler::moveStack(int stack, BattleHex dest) //inform clients about move BattleStackMoved sm; - sm.stack = curStack->ID; + sm.stack = curStack->unitId(); std::vector tiles; tiles.push_back(path.first[0]); sm.tilesToMove = tiles; @@ -1514,7 +1514,7 @@ int CGameHandler::moveStack(int stack, BattleHex dest) { //commit movement BattleStackMoved sm; - sm.stack = curStack->ID; + sm.stack = curStack->unitId(); sm.distance = path.second; sm.teleporting = false; sm.tilesToMove = tiles; @@ -1560,8 +1560,8 @@ int CGameHandler::moveStack(int stack, BattleHex dest) //handle last hex separately for deviation if (VLC->settings()->getBoolean(EGameSettings::COMBAT_ONE_HEX_TRIGGERS_OBSTACLES)) { - if (dest == battle::Unit::occupiedHex(start, curStack->doubleWide(), curStack->side) - || start == battle::Unit::occupiedHex(dest, curStack->doubleWide(), curStack->side)) + if (dest == battle::Unit::occupiedHex(start, curStack->doubleWide(), curStack->unitSide()) + || start == battle::Unit::occupiedHex(dest, curStack->doubleWide(), curStack->unitSide())) passed.clear(); //Just empty passed, obstacles will handled automatically } //handling obstacle on the final field (separate, because it affects both flying and walking stacks) @@ -4568,7 +4568,7 @@ bool CGameHandler::makeBattleAction(BattleAction &ba) if (battleTacticDist()) { - if (stack && stack->side != battleGetTacticsSide()) + if (stack && stack->unitSide() != battleGetTacticsSide()) { complain("This is not a stack of side that has tactics!"); return false; @@ -4731,7 +4731,7 @@ bool CGameHandler::makeBattleAction(BattleAction &ba) break; } - if(destinationStack && stack->ID == destinationStack->ID) //we should just move, it will be handled by following check + if(destinationStack && stack->unitId() == destinationStack->unitId()) //we should just move, it will be handled by following check { destinationStack = nullptr; } @@ -4796,7 +4796,7 @@ bool CGameHandler::makeBattleAction(BattleAction &ba) && stack->alive()) { moveStack(ba.stackNumber, startingPos); - //NOTE: curStack->ID == ba.stackNumber (rev 1431) + //NOTE: curStack->unitId() == ba.stackNumber (rev 1431) } break; } @@ -5181,7 +5181,7 @@ void CGameHandler::stackEnchantedTrigger(const CStack * st) void CGameHandler::stackTurnTrigger(const CStack *st) { BattleTriggerEffect bte; - bte.stackID = st->ID; + bte.stackID = st->unitId(); bte.effect = -1; bte.val = 0; bte.additionalInfo = 0; @@ -5214,7 +5214,7 @@ void CGameHandler::stackTurnTrigger(const CStack *st) { BattleSetStackProperty ssp; ssp.which = BattleSetStackProperty::UNBIND; - ssp.stackID = st->ID; + ssp.stackID = st->unitId(); sendAndApply(&ssp); } } @@ -5270,7 +5270,7 @@ void CGameHandler::stackTurnTrigger(const CStack *st) } } BonusList bl = *(st->getBonuses(Selector::type()(Bonus::ENCHANTER))); - int side = gs->curB->whatSide(st->owner); + int side = gs->curB->whatSide(st->unitOwner()); if(st->canCast() && gs->curB->battleGetEnchanterCounter(side) == 0) { bool cast = false; @@ -6043,7 +6043,7 @@ void CGameHandler::handleAfterAttackCasting(bool ranged, const CStack * attacker BattleStackAttacked bsa; bsa.attackerID = -1; - bsa.stackAttacked = defender->ID; + bsa.stackAttacked = defender->unitId(); bsa.damageAmount = amountToDie * defender->MaxHealth(); bsa.flags = BattleStackAttacked::SPELL_EFFECT; bsa.spellID = SpellID::SLAYER; @@ -6159,8 +6159,8 @@ void CGameHandler::makeStackDoNothing(const CStack * next) { BattleAction doNothing; doNothing.actionType = EActionType::NO_ACTION; - doNothing.side = next->side; - doNothing.stackNumber = next->ID; + doNothing.side = next->unitSide(); + doNothing.stackNumber = next->unitId(); makeAutomaticAction(next, doNothing); } @@ -6387,17 +6387,17 @@ void CGameHandler::runBattle() if (!guardianIsBig) targetHexes = stack->getSurroundingHexes(); else - summonGuardiansHelper(targetHexes, stack->getPosition(), stack->side, targetIsBig); + summonGuardiansHelper(targetHexes, stack->getPosition(), stack->unitSide(), targetIsBig); for(auto hex : targetHexes) { - if(accessibility.accessible(hex, guardianIsBig, stack->side)) //without this multiple creatures can occupy one hex + if(accessibility.accessible(hex, guardianIsBig, stack->unitSide())) //without this multiple creatures can occupy one hex { battle::UnitInfo info; info.id = gs->curB->battleNextUnitId(); info.count = std::max(1, (int)(stack->getCount() * 0.01 * summonInfo->val)); info.type = creatureData; - info.side = stack->side; + info.side = stack->unitSide(); info.position = hex; info.summoned = true; @@ -6485,7 +6485,7 @@ void CGameHandler::runBattle() if(stack && stack->alive() && !stack->waiting) { BattleTriggerEffect bte; - bte.stackID = stack->ID; + bte.stackID = stack->unitId(); bte.effect = Bonus::HP_REGENERATION; const int32_t lostHealth = stack->MaxHealth() - stack->getFirstHPleft(); @@ -6529,8 +6529,8 @@ void CGameHandler::runBattle() //unit loses its turn - empty freeze action BattleAction ba; ba.actionType = EActionType::BAD_MORALE; - ba.side = next->side; - ba.stackNumber = next->ID; + ba.side = next->unitSide(); + ba.stackNumber = next->unitId(); makeAutomaticAction(next, ba); continue; @@ -6545,8 +6545,8 @@ void CGameHandler::runBattle() { BattleAction attack; attack.actionType = EActionType::WALK_AND_ATTACK; - attack.side = next->side; - attack.stackNumber = next->ID; + attack.side = next->unitSide(); + attack.stackNumber = next->unitId(); attack.aimToHex(attackInfo.second); attack.aimToUnit(attackInfo.first); @@ -6569,8 +6569,8 @@ void CGameHandler::runBattle() { BattleAction attack; attack.actionType = EActionType::SHOOT; - attack.side = next->side; - attack.stackNumber = next->ID; + attack.side = next->unitSide(); + attack.stackNumber = next->unitId(); //TODO: select target by priority @@ -6579,7 +6579,7 @@ void CGameHandler::runBattle() for(auto & elem : gs->curB->stacks) { if(elem->unitType()->getId() != CreatureID::CATAPULT - && elem->owner != next->owner + && elem->unitOwner() != next->unitOwner() && elem->isValidTarget() && gs->curB->battleCanShoot(next, elem->getPosition())) { @@ -6614,8 +6614,8 @@ void CGameHandler::runBattle() { BattleAction attack; attack.actionType = EActionType::CATAPULT; - attack.side = next->side; - attack.stackNumber = next->ID; + attack.side = next->unitSide(); + attack.stackNumber = next->unitId(); makeAutomaticAction(next, attack); continue; @@ -6626,7 +6626,7 @@ void CGameHandler::runBattle() { TStacks possibleStacks = battleGetStacksIf([=](const CStack * s) { - return s->owner == next->owner && s->canBeHealed(); + return s->unitOwner() == next->unitOwner() && s->canBeHealed(); }); if (!possibleStacks.size()) @@ -6643,8 +6643,8 @@ void CGameHandler::runBattle() BattleAction heal; heal.actionType = EActionType::STACK_HEAL; heal.aimToUnit(toBeHealed); - heal.side = next->side; - heal.stackNumber = next->ID; + heal.side = next->unitSide(); + heal.stackNumber = next->unitId(); makeAutomaticAction(next, heal); continue; @@ -6666,7 +6666,7 @@ void CGameHandler::runBattle() else { logGlobal->trace("Activating %s", next->nodeName()); - auto nextId = next->ID; + auto nextId = next->unitId(); BattleSetActiveStack sas; sas.stack = nextId; sendAndApply(&sas); @@ -6719,7 +6719,7 @@ void CGameHandler::runBattle() if(diceSize.size() > 0 && getRandomGenerator().nextInt(1, diceSize[diceIndex]) == 1) { BattleTriggerEffect bte; - bte.stackID = next->ID; + bte.stackID = next->unitId(); bte.effect = Bonus::MORALE; bte.val = 1; bte.additionalInfo = 0; @@ -6748,7 +6748,7 @@ void CGameHandler::runBattle() bool CGameHandler::makeAutomaticAction(const CStack *stack, BattleAction &ba) { BattleSetActiveStack bsa; - bsa.stack = stack->ID; + bsa.stack = stack->unitId(); bsa.askPlayerInterface = false; sendAndApply(&bsa); @@ -7210,20 +7210,20 @@ CasualtiesAfterBattle::CasualtiesAfterBattle(const CArmedInstance * _army, const { if(st->summoned) //don't take into account temporary summoned stacks continue; - if(st->owner != color) //remove only our stacks + if(st->unitOwner() != color) //remove only our stacks continue; logGlobal->debug("Calculating casualties for %s", st->nodeName()); st->health.takeResurrected(); - if(st->slot == SlotID::ARROW_TOWERS_SLOT) + if(st->unitSlot() == SlotID::ARROW_TOWERS_SLOT) { logGlobal->debug("Ignored arrow towers stack."); } - else if(st->slot == SlotID::WAR_MACHINES_SLOT) + else if(st->unitSlot() == SlotID::WAR_MACHINES_SLOT) { - auto warMachine = st->type->warMachine; + auto warMachine = st->unitType()->warMachine; if(warMachine == ArtifactID::NONE) { @@ -7240,16 +7240,16 @@ CasualtiesAfterBattle::CasualtiesAfterBattle(const CArmedInstance * _army, const logGlobal->error("War machine in army without hero"); } } - else if(st->slot == SlotID::SUMMONED_SLOT_PLACEHOLDER) + else if(st->unitSlot() == SlotID::SUMMONED_SLOT_PLACEHOLDER) { if(st->alive() && st->getCount() > 0) { logGlobal->debug("Permanently summoned %d units.", st->getCount()); - const CreatureID summonedType = st->type->getId(); + const CreatureID summonedType = st->creatureId(); summoned[summonedType] += st->getCount(); } } - else if(st->slot == SlotID::COMMANDER_SLOT_PLACEHOLDER) + else if(st->unitSlot() == SlotID::COMMANDER_SLOT_PLACEHOLDER) { if (nullptr == st->base) { @@ -7271,25 +7271,25 @@ CasualtiesAfterBattle::CasualtiesAfterBattle(const CArmedInstance * _army, const logGlobal->error("Stack with invalid instance in commander slot. Stack: %s", st->nodeName()); } } - else if(st->base && !army->slotEmpty(st->slot)) + else if(st->base && !army->slotEmpty(st->unitSlot())) { - logGlobal->debug("Count: %d; base count: %d", st->getCount(), army->getStackCount(st->slot)); + logGlobal->debug("Count: %d; base count: %d", st->getCount(), army->getStackCount(st->unitSlot())); if(st->getCount() == 0 || !st->alive()) { logGlobal->debug("Stack has been destroyed."); - StackLocation sl(army, st->slot); + StackLocation sl(army, st->unitSlot()); newStackCounts.push_back(TStackAndItsNewCount(sl, 0)); } - else if(st->getCount() < army->getStackCount(st->slot)) + else if(st->getCount() < army->getStackCount(st->unitSlot())) { - logGlobal->debug("Stack lost %d units.", army->getStackCount(st->slot) - st->getCount()); - StackLocation sl(army, st->slot); + logGlobal->debug("Stack lost %d units.", army->getStackCount(st->unitSlot()) - st->getCount()); + StackLocation sl(army, st->unitSlot()); newStackCounts.push_back(TStackAndItsNewCount(sl, st->getCount())); } - else if(st->getCount() > army->getStackCount(st->slot)) + else if(st->getCount() > army->getStackCount(st->unitSlot())) { - logGlobal->debug("Stack gained %d units.", st->getCount() - army->getStackCount(st->slot)); - StackLocation sl(army, st->slot); + logGlobal->debug("Stack gained %d units.", st->getCount() - army->getStackCount(st->unitSlot())); + StackLocation sl(army, st->unitSlot()); newStackCounts.push_back(TStackAndItsNewCount(sl, st->getCount())); } }