mirror of
https://github.com/correl/mage.git
synced 2024-12-26 03:00:11 +00:00
Added new restriction to second target
This commit is contained in:
parent
6b977f230f
commit
40f28d1176
1 changed files with 54 additions and 22 deletions
|
@ -27,6 +27,8 @@
|
|||
*/
|
||||
package mage.cards.f;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
import java.util.UUID;
|
||||
import mage.abilities.Ability;
|
||||
|
@ -43,6 +45,7 @@ import mage.filter.FilterPermanent;
|
|||
import mage.filter.common.FilterAttackingCreature;
|
||||
import mage.filter.predicate.ObjectPlayer;
|
||||
import mage.filter.predicate.ObjectPlayerPredicate;
|
||||
import mage.filter.predicate.Predicate;
|
||||
import mage.filter.predicate.mageobject.CardTypePredicate;
|
||||
import mage.game.Controllable;
|
||||
import mage.game.Game;
|
||||
|
@ -140,7 +143,24 @@ class FalseOrdersUnblockEffect extends OneShotEffect {
|
|||
// Choose new creature to block
|
||||
if (permanent.isCreature()) {
|
||||
if (controller.chooseUse(Outcome.Benefit, "Do you want " + permanent.getLogName() + " to block an attacking creature?", source, game)) {
|
||||
TargetAttackingCreature target = new TargetAttackingCreature(1, 1, new FilterAttackingCreature(), true);
|
||||
// according to the following mail response from MTG Rules Management about False Orders:
|
||||
// "if Player A attacks Players B and C, Player B's creatures cannot block creatures attacking Player C"
|
||||
// therefore we need to single out creatures attacking the target blocker's controller (disappointing, I know)
|
||||
|
||||
List<Permanent> list = new ArrayList<>();
|
||||
for (CombatGroup combatGroup : game.getCombat().getGroups()) {
|
||||
if (combatGroup.getDefendingPlayerId().equals(permanent.getControllerId())) {
|
||||
for (UUID attackingCreatureId : combatGroup.getAttackers()) {
|
||||
Permanent targetsControllerAttacker = game.getPermanent(attackingCreatureId);
|
||||
list.add(targetsControllerAttacker);
|
||||
}
|
||||
}
|
||||
}
|
||||
Player targetsController = game.getPlayer(permanent.getControllerId());
|
||||
if (targetsController != null) {
|
||||
FilterAttackingCreature filter = new FilterAttackingCreature("creature attacking " + targetsController.getLogName());
|
||||
filter.add(new PermanentInListPredicate(list));
|
||||
TargetAttackingCreature target = new TargetAttackingCreature(1, 1, filter, true);
|
||||
if (target.canChoose(source.getSourceId(), controller.getId(), game)) {
|
||||
while (!target.isChosen() && target.canChoose(controller.getId(), game) && controller.canRespond()) {
|
||||
controller.chooseTarget(outcome, target, source, game);
|
||||
|
@ -156,10 +176,7 @@ class FalseOrdersUnblockEffect extends OneShotEffect {
|
|||
// 7/15/2006 If an attacking creature has an ability that triggers “When this creature becomes blocked,”
|
||||
// it triggers when a creature blocks it due to the Warlord’s ability only if it was unblocked at that point.
|
||||
|
||||
boolean notYetBlocked = true;
|
||||
if (!chosenGroup.getBlockers().isEmpty()) {
|
||||
notYetBlocked = false;
|
||||
}
|
||||
boolean notYetBlocked = chosenGroup.getBlockers().isEmpty();
|
||||
chosenGroup.addBlocker(permanent.getId(), controller.getId(), game);
|
||||
if (notYetBlocked) {
|
||||
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.CREATURE_BLOCKED, chosenPermanent.getId(), null));
|
||||
|
@ -168,9 +185,24 @@ class FalseOrdersUnblockEffect extends OneShotEffect {
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
class PermanentInListPredicate implements Predicate<Permanent> {
|
||||
|
||||
private final List<Permanent> permanents;
|
||||
|
||||
public PermanentInListPredicate(List<Permanent> permanents) {
|
||||
this.permanents = permanents;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Permanent input, Game game) {
|
||||
return permanents.contains(input);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue