Răsfoiți Sursa

renamed CBonusSystemNode::popBonuses to removeBonusesRecursive

Henning Koehler 7 ani în urmă
părinte
comite
d3e4fc6e7a
6 a modificat fișierele cu 13 adăugiri și 14 ștergeri
  1. 1 1
      lib/CCreatureSet.cpp
  2. 1 1
      lib/CGameState.cpp
  3. 2 2
      lib/HeroBonus.cpp
  4. 1 2
      lib/HeroBonus.h
  5. 4 4
      lib/NetPacksLib.cpp
  6. 4 4
      lib/battle/BattleInfo.cpp

+ 1 - 1
lib/CCreatureSet.cpp

@@ -825,7 +825,7 @@ void CCommanderInstance::setAlive (bool Alive)
 	alive = Alive;
 	if (!alive)
 	{
-		popBonuses(Bonus::UntilCommanderKilled);
+		removeBonusesRecursive(Bonus::UntilCommanderKilled);
 	}
 }
 

+ 1 - 1
lib/CGameState.cpp

@@ -1243,7 +1243,7 @@ void CGameState::prepareCrossoverHeroes(std::vector<CGameState::CampaignHeroRepl
 	// Removing short-term bonuses
 	for(CGHeroInstance * cgh : crossoverHeroes)
 	{
-		cgh->popBonuses(CSelector(Bonus::OneDay)
+		cgh->removeBonusesRecursive(CSelector(Bonus::OneDay)
 			.Or(CSelector(Bonus::OneWeek))
 			.Or(CSelector(Bonus::NTurns))
 			.Or(CSelector(Bonus::NDays))

+ 2 - 2
lib/HeroBonus.cpp

@@ -791,7 +791,7 @@ void CBonusSystemNode::detachFrom(CBonusSystemNode *parent)
 	CBonusSystemNode::treeHasChanged();
 }
 
-void CBonusSystemNode::popBonuses(const CSelector &s)
+void CBonusSystemNode::removeBonusesRecursive(const CSelector &s)
 {
 	BonusList bl;
 	exportedBonuses.getBonuses(bl, s, Selector::all);
@@ -799,7 +799,7 @@ void CBonusSystemNode::popBonuses(const CSelector &s)
 		removeBonus(b);
 
 	for(CBonusSystemNode *child : children)
-		child->popBonuses(s);
+		child->removeBonusesRecursive(s);
 }
 
 void CBonusSystemNode::reduceBonusDurations(const CSelector &s)

+ 1 - 2
lib/HeroBonus.h

@@ -710,13 +710,12 @@ public:
 	void unpropagateBonus(std::shared_ptr<Bonus> b);
 	void removeBonus(const std::shared_ptr<Bonus>& b);
 	void removeBonuses(const CSelector &selector);
+	void removeBonusesRecursive(const CSelector &s);
 	void newRedDescendant(CBonusSystemNode *descendant); //propagation needed
 	void removedRedDescendant(CBonusSystemNode *descendant); //de-propagation needed
 
 	bool isIndependentNode() const; //node is independent when it has no parents nor children
 	bool actsAsBonusSourceOnly() const;
-	///removes bonuses by selector
-	void popBonuses(const CSelector &s);
 	///updates count of remaining turns and removes outdated bonuses by selector
 	void reduceBonusDurations(const CSelector &s);
 	virtual std::string bonusToString(const std::shared_ptr<Bonus>& bonus, bool description) const {return "";}; //description or bonus name

+ 4 - 4
lib/NetPacksLib.cpp

@@ -1084,7 +1084,7 @@ DLL_LINKAGE void NewTurn::applyGs(CGameState *gs)
 	gs->day = day;
 
 	// Update bonuses before doing anything else so hero don't get more MP than needed
-	gs->globalEffects.popBonuses(Bonus::OneDay); //works for children -> all game objs
+	gs->globalEffects.removeBonusesRecursive(Bonus::OneDay); //works for children -> all game objs
 	gs->globalEffects.reduceBonusDurations(Bonus::NDays);
 	gs->globalEffects.reduceBonusDurations(Bonus::OneWeek);
 	//TODO not really a single root hierarchy, what about bonuses placed elsewhere? [not an issue with H3 mechanics but in the future...]
@@ -1286,7 +1286,7 @@ void BattleResult::applyGs(CGameState *gs)
 	{
 		if(auto h = gs->curB->battleGetFightingHero(i))
 		{
-			h->popBonuses(Bonus::OneBattle); 	//remove any "until next battle" bonuses
+			h->removeBonusesRecursive(Bonus::OneBattle); 	//remove any "until next battle" bonuses
 			if (h->commander && h->commander->alive)
 			{
 				for (auto art : h->commander->artifactsWorn) //increment bonuses for commander artifacts
@@ -1342,7 +1342,7 @@ DLL_LINKAGE void BattleAttack::applyGs(CGameState * gs)
 	for(BattleStackAttacked & stackAttacked : bsa)
 		stackAttacked.applyGs(gs);
 
-	attacker->popBonuses(Bonus::UntilAttack);
+	attacker->removeBonusesRecursive(Bonus::UntilAttack);
 }
 
 DLL_LINKAGE void StartAction::applyGs(CGameState *gs)
@@ -1542,7 +1542,7 @@ DLL_LINKAGE void BattleSetStackProperty::applyGs(CGameState * gs)
 		}
 		case UNBIND:
 		{
-			stack->popBonuses(Selector::type(Bonus::BIND_EFFECT));
+			stack->removeBonusesRecursive(Selector::type(Bonus::BIND_EFFECT));
 			break;
 		}
 		case CLONED:

+ 4 - 4
lib/battle/BattleInfo.cpp

@@ -781,7 +781,7 @@ void BattleInfo::nextTurn(uint32_t unitId)
 	CStack * st = getStack(activeStack);
 
 	//remove bonuses that last until when stack gets new turn
-	st->popBonuses(Bonus::UntilGetsTurn);
+	st->removeBonusesRecursive(Bonus::UntilGetsTurn);
 
 	st->afterGetsTurn();
 }
@@ -852,7 +852,7 @@ void BattleInfo::setUnitState(uint32_t id, const JsonNode & data, int64_t health
 
 	if(healthDelta < 0)
 	{
-		changedStack->popBonuses(Bonus::UntilBeingAttacked);
+		changedStack->removeBonusesRecursive(Bonus::UntilBeingAttacked);
 	}
 
 	resurrected = resurrected || (killed && changedStack->alive());
@@ -881,7 +881,7 @@ void BattleInfo::setUnitState(uint32_t id, const JsonNode & data, int64_t health
 			else
 				return false;
 		};
-		changedStack->popBonuses(selector);
+		changedStack->removeBonusesRecursive(selector);
 	}
 
 	if(!changedStack->alive() && changedStack->isClone())
@@ -989,7 +989,7 @@ void BattleInfo::removeUnitBonus(uint32_t id, const std::vector<Bonus> & bonus)
 			&& one.effectRange == b->effectRange
 			&& one.description == b->description;
 		};
-		sta->popBonuses(selector);
+		sta->removeBonusesRecursive(selector);
 	}
 }