diff --git a/Mage.Sets/src/mage/cards/c/ChampionsOfMinasTirith.java b/Mage.Sets/src/mage/cards/c/ChampionsOfMinasTirith.java new file mode 100644 index 00000000000..391ee8adb97 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/ChampionsOfMinasTirith.java @@ -0,0 +1,115 @@ +package mage.cards.c; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.BeginningOfCombatTriggeredAbility; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.condition.common.MonarchIsSourceControllerCondition; +import mage.abilities.costs.Cost; +import mage.abilities.decorator.ConditionalTriggeredAbility; +import mage.abilities.dynamicvalue.common.CardsInTargetPlayerHandCount; +import mage.abilities.effects.Effect; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.BecomesMonarchSourceEffect; +import mage.abilities.effects.common.DoIfCostPaid; +import mage.abilities.effects.common.combat.TargetPlayerCantAttackYouEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.*; +import mage.game.Game; +import mage.players.Player; +import mage.util.ManaUtil; + +import java.util.UUID; + +/** + * @author Susucr + */ +public final class ChampionsOfMinasTirith extends CardImpl { + + public ChampionsOfMinasTirith(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{5}{W}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.SOLDIER); + this.power = new MageInt(4); + this.toughness = new MageInt(6); + + // When Champions of Minas Tirith enters the battlefield, you become the monarch. + this.addAbility(new EntersBattlefieldTriggeredAbility(new BecomesMonarchSourceEffect(), false)); + + // At the beginning of combat on each opponent's turn, if you're the monarch, that opponent may pay {X}, where X is the number of cards in their hand. If they don't, they can't attack you this combat. + this.addAbility(new ConditionalTriggeredAbility( + new BeginningOfCombatTriggeredAbility( + Zone.BATTLEFIELD, + new ChampionsOfMinasTirithEffect(), + TargetController.OPPONENT, + false, + true + ), + MonarchIsSourceControllerCondition.instance, + "At the beginning of combat on each opponent's turn, if you're the monarch, that opponent may pay {X}, " + + "where X is the number of cards in their hand. If they don't, they can't attack you this combat." + )); + } + + private ChampionsOfMinasTirith(final ChampionsOfMinasTirith card) { + super(card); + } + + @Override + public ChampionsOfMinasTirith copy() { + return new ChampionsOfMinasTirith(this); + } +} + +class ChampionsOfMinasTirithEffect extends OneShotEffect { + + ChampionsOfMinasTirithEffect() { + super(Outcome.Benefit); + } + + private ChampionsOfMinasTirithEffect(final ChampionsOfMinasTirithEffect effect) { + super(effect); + } + + @Override + public ChampionsOfMinasTirithEffect copy() { + return new ChampionsOfMinasTirithEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Player player = game.getPlayer(source.getControllerId()); + if (player == null) { + return false; + } + + return new ChampionsOfMinasTirithDoIfCostPaid( + new TargetPlayerCantAttackYouEffect(Duration.EndOfCombat), + ManaUtil.createManaCost(CardsInTargetPlayerHandCount.instance, game, source, this), + "Pay to be able to attack " + player.getName() + " this combat?" + ).setTargetPointer(targetPointer).apply(game, source); + } +} + +class ChampionsOfMinasTirithDoIfCostPaid extends DoIfCostPaid { + + ChampionsOfMinasTirithDoIfCostPaid(Effect effect, Cost cost, String chooseText) { + super(null, effect, cost, chooseText, false); + } + + private ChampionsOfMinasTirithDoIfCostPaid(final ChampionsOfMinasTirithDoIfCostPaid effect) { + super(effect); + } + + @Override + public ChampionsOfMinasTirithDoIfCostPaid copy() { + return new ChampionsOfMinasTirithDoIfCostPaid(this); + } + + @Override + protected Player getPayingPlayer(Game game, Ability source) { + return game.getPlayer(targetPointer.getFirst(game, source)); + } +} \ No newline at end of file diff --git a/Mage.Sets/src/mage/sets/TalesOfMiddleEarthCommander.java b/Mage.Sets/src/mage/sets/TalesOfMiddleEarthCommander.java index 4581d219c35..45b2b4f227c 100644 --- a/Mage.Sets/src/mage/sets/TalesOfMiddleEarthCommander.java +++ b/Mage.Sets/src/mage/sets/TalesOfMiddleEarthCommander.java @@ -50,6 +50,7 @@ public final class TalesOfMiddleEarthCommander extends ExpansionSet { cards.add(new SetCardInfo("Castle Ardenvale", 361, Rarity.MYTHIC, mage.cards.c.CastleArdenvale.class)); cards.add(new SetCardInfo("Cavern of Souls", 362, Rarity.MYTHIC, mage.cards.c.CavernOfSouls.class)); cards.add(new SetCardInfo("Cavern-Hoard Dragon", 31, Rarity.RARE, mage.cards.c.CavernHoardDragon.class)); + cards.add(new SetCardInfo("Champions of Minas Tirith", 10, Rarity.RARE, mage.cards.c.ChampionsOfMinasTirith.class)); cards.add(new SetCardInfo("Choked Estuary", 299, Rarity.RARE, mage.cards.c.ChokedEstuary.class)); cards.add(new SetCardInfo("Chromatic Lantern", 275, Rarity.RARE, mage.cards.c.ChromaticLantern.class)); cards.add(new SetCardInfo("Cirdan the Shipwright", 50, Rarity.RARE, mage.cards.c.CirdanTheShipwright.class)); diff --git a/Mage/src/main/java/mage/abilities/costs/mana/GenericManaCost.java b/Mage/src/main/java/mage/abilities/costs/mana/GenericManaCost.java index 4310ab67c15..580dcfbf3db 100644 --- a/Mage/src/main/java/mage/abilities/costs/mana/GenericManaCost.java +++ b/Mage/src/main/java/mage/abilities/costs/mana/GenericManaCost.java @@ -20,7 +20,7 @@ public class GenericManaCost extends ManaCostImpl { this.options.addMana(Mana.GenericMana(mana)); } - public GenericManaCost(GenericManaCost manaCost) { + protected GenericManaCost(GenericManaCost manaCost) { super(manaCost); this.mana = manaCost.mana; } diff --git a/Mage/src/main/java/mage/abilities/effects/common/DoIfCostPaid.java b/Mage/src/main/java/mage/abilities/effects/common/DoIfCostPaid.java index 95af188d55a..47393f6ceb8 100644 --- a/Mage/src/main/java/mage/abilities/effects/common/DoIfCostPaid.java +++ b/Mage/src/main/java/mage/abilities/effects/common/DoIfCostPaid.java @@ -30,21 +30,25 @@ public class DoIfCostPaid extends OneShotEffect { } public DoIfCostPaid(Effect effectOnPaid, Effect effectOnNotPaid, Cost cost, boolean optional) { - this(effectOnPaid, cost, null, optional); - if (effectOnNotPaid != null) { - this.otherwiseEffects.add(effectOnNotPaid); - } + this(effectOnPaid, effectOnNotPaid, cost, null, optional); } public DoIfCostPaid(Effect effectOnPaid, Cost cost, String chooseUseText) { - this(effectOnPaid, cost, chooseUseText, true); + this(effectOnPaid, null, cost, chooseUseText, true); } public DoIfCostPaid(Effect effectOnPaid, Cost cost, String chooseUseText, boolean optional) { + this(effectOnPaid, null, cost, chooseUseText, optional); + } + + public DoIfCostPaid(Effect effectOnPaid, Effect effectOnNotPaid, Cost cost, String chooseUseText, boolean optional) { super(Outcome.Benefit); if (effectOnPaid != null) { this.executingEffects.add(effectOnPaid); } + if (effectOnNotPaid != null) { + this.otherwiseEffects.add(effectOnNotPaid); + } this.cost = cost; this.chooseUseText = chooseUseText; this.optional = optional; @@ -149,7 +153,7 @@ public class DoIfCostPaid extends OneShotEffect { public Cost getCost() { return cost; } - + @Override public String getText(Mode mode) { if (!staticText.isEmpty()) { diff --git a/Mage/src/main/java/mage/abilities/effects/common/combat/CantAttackYouEffect.java b/Mage/src/main/java/mage/abilities/effects/common/combat/TargetPlayerCantAttackYouEffect.java similarity index 55% rename from Mage/src/main/java/mage/abilities/effects/common/combat/CantAttackYouEffect.java rename to Mage/src/main/java/mage/abilities/effects/common/combat/TargetPlayerCantAttackYouEffect.java index 5b949f81687..a363c2a9eab 100644 --- a/Mage/src/main/java/mage/abilities/effects/common/combat/CantAttackYouEffect.java +++ b/Mage/src/main/java/mage/abilities/effects/common/combat/TargetPlayerCantAttackYouEffect.java @@ -1,45 +1,44 @@ package mage.abilities.effects.common.combat; -import java.util.UUID; - import mage.abilities.Ability; import mage.abilities.effects.RestrictionEffect; import mage.constants.Duration; import mage.game.Game; import mage.game.permanent.Permanent; -/** - * @author TheElk801 - */ -public class CantAttackYouEffect extends RestrictionEffect { +import java.util.UUID; - public CantAttackYouEffect(Duration duration) { +/** + * @author Susucr + */ +public class TargetPlayerCantAttackYouEffect extends RestrictionEffect { + + public TargetPlayerCantAttackYouEffect(Duration duration) { super(duration); } - protected CantAttackYouEffect(final CantAttackYouEffect effect) { + protected TargetPlayerCantAttackYouEffect(final TargetPlayerCantAttackYouEffect effect) { super(effect); } @Override - public CantAttackYouEffect copy() { - return new CantAttackYouEffect(this); + public TargetPlayerCantAttackYouEffect copy() { + return new TargetPlayerCantAttackYouEffect(this); } @Override public boolean applies(Permanent permanent, Ability source, Game game) { - return this.getTargetPointer().getTargets(game, source).contains(permanent.getId()); + return this.getTargetPointer().getTargets(game, source).contains(permanent.getControllerId()); } @Override public boolean canAttack(Permanent attacker, UUID defenderId, Ability source, Game game, boolean canUseChooseDialogs) { - if (defenderId == null - || game.getState().getPlayersInRange(attacker.getControllerId(), game).size() == 2) { // just 2 players left, so it may attack you + if (defenderId == null) { return true; } - // A planeswalker controlled by the controller is the defender + // A planeswalker/battle controlled by the defender, not affected by the effect if (game.getPermanent(defenderId) != null) { - return !game.getPermanent(defenderId).getControllerId().equals(source.getControllerId()); + return true; } // The controller is the defender return !defenderId.equals(source.getControllerId());