浏览代码

Fixed creature`s aimed spell targeting.

AlexVinS 9 年之前
父节点
当前提交
8eca149eb3
共有 1 个文件被更改,包括 5 次插入12 次删除
  1. 5 12
      client/battle/CBattleInterface.cpp

+ 5 - 12
client/battle/CBattleInterface.cpp

@@ -1586,8 +1586,8 @@ void CBattleInterface::activateStack()
 		stackCanCastSpell = true;
 		stackCanCastSpell = true;
 		if(randomSpellcaster)
 		if(randomSpellcaster)
 			creatureSpellToCast = -1; //spell will be set later on cast
 			creatureSpellToCast = -1; //spell will be set later on cast
-
-		creatureSpellToCast = curInt->cb->battleGetRandomStackSpell(s, CBattleInfoCallback::RANDOM_AIMED); //faerie dragon can cast only one spell until their next move
+		else
+			creatureSpellToCast = curInt->cb->battleGetRandomStackSpell(s, CBattleInfoCallback::RANDOM_AIMED); //faerie dragon can cast only one spell until their next move
 		//TODO: what if creature can cast BOTH random genie spell and aimed spell?
 		//TODO: what if creature can cast BOTH random genie spell and aimed spell?
 	}
 	}
 	else
 	else
@@ -1633,23 +1633,16 @@ void CBattleInterface::getPossibleActionsForStack(const CStack * stack)
 		{
 		{
 			if (stack->hasBonusOfType (Bonus::SPELLCASTER))
 			if (stack->hasBonusOfType (Bonus::SPELLCASTER))
 			{
 			{
-				 //TODO: poll possible spells
-				const CSpell * spell;
-				BonusList spellBonuses = *stack->getBonuses (Selector::type(Bonus::SPELLCASTER));
-				for (Bonus * spellBonus : spellBonuses)
+				if(creatureSpellToCast != -1)
 				{
 				{
-					spell = SpellID(spellBonus->subtype).toSpell();
-
+					const CSpell * spell = SpellID(creatureSpellToCast).toSpell();
 					PossibleActions act = getCasterAction(spell, stack);
 					PossibleActions act = getCasterAction(spell, stack);
-
 					if(act == NO_LOCATION)
 					if(act == NO_LOCATION)
 						logGlobal->error("NO_LOCATION action target is not yet supported for creatures");
 						logGlobal->error("NO_LOCATION action target is not yet supported for creatures");
 					else
 					else
 						possibleActions.push_back(act);
 						possibleActions.push_back(act);
+
 				}
 				}
-				std::sort(possibleActions.begin(), possibleActions.end());
-				auto it = std::unique (possibleActions.begin(), possibleActions.end());
-				possibleActions.erase (it, possibleActions.end());
 			}
 			}
 			if (stack->hasBonusOfType (Bonus::RANDOM_SPELLCASTER))
 			if (stack->hasBonusOfType (Bonus::RANDOM_SPELLCASTER))
 				possibleActions.push_back (RANDOM_GENIE_SPELL);
 				possibleActions.push_back (RANDOM_GENIE_SPELL);