mirror of
https://github.com/Relintai/mtg-forge-ios.git
synced 2025-01-22 09:47:19 +01:00
- Some improvements to the Splice AI: do not reconsider the SA unless at least something was chosen for splice to save processing time; reset the targets on the main SA because it'll need to be retargeted anyway.
git-svn-id: http://svn.slightlymagic.net/forge/trunk@35805 269b9781-a132-4a9b-9d4e-f004f1b56b58
This commit is contained in:
parent
b140dcefc0
commit
52863adf49
@ -76,12 +76,17 @@ public class ComputerUtil {
|
|||||||
if (sa.isSpell() && !source.isCopiedSpell()) {
|
if (sa.isSpell() && !source.isCopiedSpell()) {
|
||||||
if (source.getType().hasStringType("Arcane")) {
|
if (source.getType().hasStringType("Arcane")) {
|
||||||
sa = AbilityUtils.addSpliceEffects(sa);
|
sa = AbilityUtils.addSpliceEffects(sa);
|
||||||
AiPlayDecision postSpliceDecision = ((PlayerControllerAi)ai.getController()).getAi().canPlaySa(sa);
|
if (sa.getSplicedCards() != null && !sa.getSplicedCards().isEmpty() && ai.getController().isAI()) {
|
||||||
if (postSpliceDecision != AiPlayDecision.WillPlay) {
|
// we need to reconsider and retarget the SA after additional SAs have been added onto it via splice,
|
||||||
// for whatever reason the AI doesn't want to play the thing with the subs at this time
|
// otherwise the AI will fail to add the card to stack and that'll knock it out of the game
|
||||||
|
sa.resetTargets();
|
||||||
|
if (((PlayerControllerAi) ai.getController()).getAi().canPlaySa(sa) != AiPlayDecision.WillPlay) {
|
||||||
|
// for whatever reason the AI doesn't want to play the thing with the spliced subs anymore,
|
||||||
|
// proceeding past this point may result in an illegal play
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
source.setCastSA(sa);
|
source.setCastSA(sa);
|
||||||
sa.setLastStateBattlefield(game.getLastStateBattlefield());
|
sa.setLastStateBattlefield(game.getLastStateBattlefield());
|
||||||
|
Loading…
Reference in New Issue
Block a user