瀏覽代碼

Add some diagnostics for inablilty to place all stacks on battlefield

Ivan Savenko 5 月之前
父節點
當前提交
afb22e52eb
共有 2 個文件被更改,包括 8 次插入0 次删除
  1. 2 0
      lib/battle/BattleInfo.cpp
  2. 6 0
      lib/mapObjects/CRewardableObject.cpp

+ 2 - 0
lib/battle/BattleInfo.cpp

@@ -342,6 +342,8 @@ std::unique_ptr<BattleInfo> BattleInfo::setupBattle(IGameInfoCallback *cb, const
 
 
 			if (pos.isValid())
 			if (pos.isValid())
 				currentBattle->generateNewStack(currentBattle->nextUnitId(), *i->second, side, i->first, pos);
 				currentBattle->generateNewStack(currentBattle->nextUnitId(), *i->second, side, i->first, pos);
+			else
+				logMod->warn("Invalid battlefield layout! Failed to find position for unit %d for %s", k, side == BattleSide::ATTACKER ? "attacker" : "defender");
 		}
 		}
 	}
 	}
 
 

+ 6 - 0
lib/mapObjects/CRewardableObject.cpp

@@ -85,6 +85,12 @@ void CRewardableObject::battleFinished(IGameEventCallback & gameEvents, const CG
 {
 {
 	if (result.winner == BattleSide::ATTACKER)
 	if (result.winner == BattleSide::ATTACKER)
 	{
 	{
+		while(!stacks.empty())
+		{
+			logMod->warn("Attacker won, but defender still has remaining units in configurable map objects! Make sure that guards configuration is valid!");
+			gameEvents.eraseStack(StackLocation(id, stacks.begin()->first));
+		}
+
 		doHeroVisit(gameEvents, hero);
 		doHeroVisit(gameEvents, hero);
 	}
 	}
 }
 }