From f1cd9ca881828732b647d922836adb5db4c1b7c7 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Tue, 8 Sep 2020 11:10:48 -0400 Subject: [PATCH] [ZNR] Implemented Kargan Intimidator --- .../src/mage/cards/k/KarganIntimidator.java | 109 ++++++++++++++++++ Mage.Sets/src/mage/sets/ZendikarRising.java | 1 + Mage/src/main/java/mage/abilities/Modes.java | 29 +++++ 3 files changed, 139 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/k/KarganIntimidator.java diff --git a/Mage.Sets/src/mage/cards/k/KarganIntimidator.java b/Mage.Sets/src/mage/cards/k/KarganIntimidator.java new file mode 100644 index 00000000000..d5869b20fe2 --- /dev/null +++ b/Mage.Sets/src/mage/cards/k/KarganIntimidator.java @@ -0,0 +1,109 @@ +package mage.cards.k; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.Mode; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.costs.mana.GenericManaCost; +import mage.abilities.effects.RestrictionEffect; +import mage.abilities.effects.common.continuous.BecomesCreatureTypeTargetEffect; +import mage.abilities.effects.common.continuous.BoostSourceEffect; +import mage.abilities.effects.common.continuous.GainAbilityTargetEffect; +import mage.abilities.keyword.TrampleAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.filter.FilterPermanent; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.target.TargetPermanent; +import mage.target.common.TargetCreaturePermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class KarganIntimidator extends CardImpl { + + private static final FilterPermanent filter = new FilterPermanent(SubType.WARRIOR, "Warrior"); + + public KarganIntimidator(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{R}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.WARRIOR); + this.power = new MageInt(3); + this.toughness = new MageInt(1); + + // Cowards can't block Warriors. + this.addAbility(new SimpleStaticAbility(new KarganIntimidatorEffect())); + + // {1}: Choose one that hasn't been chosen this turn — + // • Kargan Intimidator gets +1/+1 until end of turn. + Ability ability = new SimpleActivatedAbility( + new BoostSourceEffect(1, 1, Duration.EndOfTurn), new GenericManaCost(1) + ); + ability.getModes().setEachModeOnlyOnce(true); + ability.getModes().setResetEachTurn(true); + + // • Target creature becomes a Coward until end of turn. + Mode mode = new Mode(new BecomesCreatureTypeTargetEffect( + Duration.EndOfTurn, SubType.COWARD + ).setText("Target creature becomes a Coward until end of turn")); + mode.addTarget(new TargetCreaturePermanent()); + ability.addMode(mode); + + // • Target Warrior gains trample until end of turn. + mode = new Mode(new GainAbilityTargetEffect(TrampleAbility.getInstance(), Duration.EndOfTurn)); + mode.addTarget(new TargetPermanent(filter)); + ability.addMode(mode); + this.addAbility(ability); + } + + private KarganIntimidator(final KarganIntimidator card) { + super(card); + } + + @Override + public KarganIntimidator copy() { + return new KarganIntimidator(this); + } +} + +class KarganIntimidatorEffect extends RestrictionEffect { + + KarganIntimidatorEffect() { + super(Duration.WhileOnBattlefield); + staticText = "Cowards can't block Warriors"; + } + + KarganIntimidatorEffect(final KarganIntimidatorEffect effect) { + super(effect); + } + + @Override + public boolean applies(Permanent permanent, Ability source, Game game) { + Permanent sourcePermanent = game.getPermanent(source.getSourceId()); + return sourcePermanent != null; + } + + @Override + public boolean canBlock(Permanent attacker, Permanent blocker, Ability source, Game game, boolean canUseChooseDialogs) { + if (attacker != null && blocker != null) { + Permanent sourcePermanent = game.getPermanent(source.getSourceId()); + if (sourcePermanent != null && attacker.hasSubtype(SubType.WARRIOR, game)) { + return !blocker.hasSubtype(SubType.COWARD, game); + } + } + return true; + } + + @Override + public KarganIntimidatorEffect copy() { + return new KarganIntimidatorEffect(this); + } +} diff --git a/Mage.Sets/src/mage/sets/ZendikarRising.java b/Mage.Sets/src/mage/sets/ZendikarRising.java index 0960816d166..cdef192b43f 100644 --- a/Mage.Sets/src/mage/sets/ZendikarRising.java +++ b/Mage.Sets/src/mage/sets/ZendikarRising.java @@ -178,6 +178,7 @@ public final class ZendikarRising extends ExpansionSet { cards.add(new SetCardInfo("Kabira Outrider", 18, Rarity.COMMON, mage.cards.k.KabiraOutrider.class)); cards.add(new SetCardInfo("Kabira Plateau", 19, Rarity.UNCOMMON, mage.cards.k.KabiraPlateau.class)); cards.add(new SetCardInfo("Kabira Takedown", 19, Rarity.UNCOMMON, mage.cards.k.KabiraTakedown.class)); + cards.add(new SetCardInfo("Kargan Intimidator", 145, Rarity.RARE, mage.cards.k.KarganIntimidator.class)); cards.add(new SetCardInfo("Kaza, Roil Chaser", 225, Rarity.RARE, mage.cards.k.KazaRoilChaser.class)); cards.add(new SetCardInfo("Kazandu Nectarpot", 190, Rarity.COMMON, mage.cards.k.KazanduNectarpot.class)); cards.add(new SetCardInfo("Kazuul's Cliffs", 146, Rarity.UNCOMMON, mage.cards.k.KazuulsCliffs.class)); diff --git a/Mage/src/main/java/mage/abilities/Modes.java b/Mage/src/main/java/mage/abilities/Modes.java index 0aea5a49ff4..587162a0c54 100644 --- a/Mage/src/main/java/mage/abilities/Modes.java +++ b/Mage/src/main/java/mage/abilities/Modes.java @@ -38,6 +38,8 @@ public class Modes extends LinkedHashMap { private boolean isRandom = false; private String chooseText = null; private boolean allWhenKicked = false; + private boolean resetEachTurn = false; + private int turnNum = 0; public Modes() { this.currentMode = new Mode(); @@ -71,6 +73,9 @@ public class Modes extends LinkedHashMap { this.isRandom = modes.isRandom; this.chooseText = modes.chooseText; + this.allWhenKicked = modes.allWhenKicked; + this.resetEachTurn = modes.resetEachTurn; + this.turnNum = modes.turnNum; if (modes.getSelectedModes().isEmpty()) { this.currentMode = values().iterator().next(); } else { @@ -217,6 +222,12 @@ public class Modes extends LinkedHashMap { } public boolean choose(Game game, Ability source) { + if (this.isResetEachTurn()) { + if (this.turnNum != game.getTurnNum()) { + this.clearAlreadySelectedModes(source, game); + this.turnNum = game.getTurnNum(); + } + } if (this.allWhenKicked && KickedCondition.instance.apply(game, source)) { this.setMinModes(0); this.setMaxModes(3); @@ -332,6 +343,13 @@ public class Modes extends LinkedHashMap { } } + private void clearAlreadySelectedModes(Ability source, Game game) { + for (UUID modeId : getSelectedModes()) { + String key = getKey(source, game, modeId); + game.getState().setValue(key, false); + } + } + /** * Adds a mode as selected. If the mode is already selected, it copies the * mode and adds it to the duplicate modes @@ -436,6 +454,9 @@ public class Modes extends LinkedHashMap { if (isEachModeOnlyOnce()) { sb.append(" that hasn't been chosen"); } + if (isResetEachTurn()) { + sb.append(" this turn"); + } if (isEachModeMoreThanOnce()) { sb.append(". You may choose the same mode more than once."); @@ -489,6 +510,14 @@ public class Modes extends LinkedHashMap { this.allWhenKicked = allWhenKicked; } + public boolean isResetEachTurn() { + return resetEachTurn; + } + + public void setResetEachTurn(boolean resetEachTurn) { + this.resetEachTurn = resetEachTurn; + } + public void setChooseText(String chooseText) { this.chooseText = chooseText; }