[C21] fixed issues with Nils, Discipline Enforcer (fixes #7800)

This commit is contained in:
Evan Kranzler 2021-05-04 18:32:17 -04:00
parent 008ab3cace
commit 28dfaaffa1

View file

@ -6,25 +6,24 @@ import mage.abilities.common.BeginningOfEndStepTriggeredAbility;
import mage.abilities.common.SimpleStaticAbility; import mage.abilities.common.SimpleStaticAbility;
import mage.abilities.costs.mana.ManaCosts; import mage.abilities.costs.mana.ManaCosts;
import mage.abilities.costs.mana.ManaCostsImpl; import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.OneShotEffect;
import mage.abilities.effects.common.combat.CantAttackYouUnlessPayManaAllEffect; import mage.abilities.effects.common.combat.CantAttackYouUnlessPayManaAllEffect;
import mage.abilities.effects.common.counter.AddCountersTargetEffect;
import mage.cards.CardImpl; import mage.cards.CardImpl;
import mage.cards.CardSetInfo; import mage.cards.CardSetInfo;
import mage.constants.CardType; import mage.constants.*;
import mage.constants.SubType;
import mage.constants.SuperType;
import mage.constants.TargetController;
import mage.counters.CounterType; import mage.counters.CounterType;
import mage.filter.FilterPermanent; import mage.filter.FilterPermanent;
import mage.filter.common.FilterCreaturePermanent; import mage.filter.common.FilterCreaturePermanent;
import mage.filter.predicate.permanent.ControllerIdPredicate;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent; import mage.game.events.GameEvent;
import mage.game.permanent.Permanent; import mage.game.permanent.Permanent;
import mage.players.Player; import mage.players.Player;
import mage.target.Target;
import mage.target.TargetPermanent; import mage.target.TargetPermanent;
import mage.target.targetadjustment.TargetAdjuster; import mage.target.targetadjustment.TargetAdjuster;
import mage.target.targetpointer.EachTargetPointer;
import java.util.Objects;
import java.util.UUID; import java.util.UUID;
/** /**
@ -43,10 +42,7 @@ public final class NilsDisciplineEnforcer extends CardImpl {
// At the beginning of your end step, for each player, put a +1/+1 counter on up to one target creature that player controls. // At the beginning of your end step, for each player, put a +1/+1 counter on up to one target creature that player controls.
Ability ability = new BeginningOfEndStepTriggeredAbility( Ability ability = new BeginningOfEndStepTriggeredAbility(
new AddCountersTargetEffect(CounterType.P1P1.createInstance()) new NilsDisciplineEnforcerEffect(), TargetController.YOU, false
.setTargetPointer(new EachTargetPointer())
.setText("for each player, put a +1/+1 counter on up to one target creature that player controls"),
TargetController.YOU, false
); );
ability.setTargetAdjuster(NilsDisciplineEnforcerAdjuster.instance); ability.setTargetAdjuster(NilsDisciplineEnforcerAdjuster.instance);
this.addAbility(ability); this.addAbility(ability);
@ -77,11 +73,43 @@ enum NilsDisciplineEnforcerAdjuster implements TargetAdjuster {
continue; continue;
} }
FilterPermanent filter = new FilterCreaturePermanent("creature controlled by " + player.getName()); FilterPermanent filter = new FilterCreaturePermanent("creature controlled by " + player.getName());
filter.add(new ControllerIdPredicate(playerId));
ability.addTarget(new TargetPermanent(0, 1, filter)); ability.addTarget(new TargetPermanent(0, 1, filter));
} }
} }
} }
class NilsDisciplineEnforcerCountersEffect extends OneShotEffect {
NilsDisciplineEnforcerCountersEffect() {
super(Outcome.Benefit);
staticText = "for each player, put a +1/+1 counter on up to one target creature that player controls";
}
private NilsDisciplineEnforcerCountersEffect(final NilsDisciplineEnforcerCountersEffect effect) {
super(effect);
}
@Override
public NilsDisciplineEnforcerCountersEffect copy() {
return new NilsDisciplineEnforcerCountersEffect(this);
}
@Override
public boolean apply(Game game, Ability source) {
source.getTargets()
.stream()
.map(Target::getFirstTarget)
.map(game::getPermanent)
.filter(Objects::nonNull)
.map(permanent -> permanent.addCounters(
CounterType.P1P1.createInstance(),
source.getControllerId(), source, game
));
return true;
}
}
class NilsDisciplineEnforcerEffect extends CantAttackYouUnlessPayManaAllEffect { class NilsDisciplineEnforcerEffect extends CantAttackYouUnlessPayManaAllEffect {
NilsDisciplineEnforcerEffect() { NilsDisciplineEnforcerEffect() {