From 204418a8fd29d935daf6a6972bedfbffc3177469 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Tue, 8 Sep 2020 11:23:19 -0400 Subject: [PATCH] [ZNR] Implemented Maddening Cacophony --- .../src/mage/cards/m/MaddeningCacophony.java | 75 +++++++++++++++++++ Mage.Sets/src/mage/sets/ZendikarRising.java | 1 + 2 files changed, 76 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/m/MaddeningCacophony.java diff --git a/Mage.Sets/src/mage/cards/m/MaddeningCacophony.java b/Mage.Sets/src/mage/cards/m/MaddeningCacophony.java new file mode 100644 index 00000000000..5633a8d5635 --- /dev/null +++ b/Mage.Sets/src/mage/cards/m/MaddeningCacophony.java @@ -0,0 +1,75 @@ +package mage.cards.m; + +import mage.abilities.Ability; +import mage.abilities.condition.common.KickedCondition; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.KickerAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.game.Game; +import mage.players.Player; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class MaddeningCacophony extends CardImpl { + + public MaddeningCacophony(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{1}{U}"); + + // Kicker {3}{U} + this.addAbility(new KickerAbility(new ManaCostsImpl<>("{3}{U}"))); + + // Each opponent mills eight cards. If this spell was kicked, instead each opponent mills half their library, rounded up. + this.getSpellAbility().addEffect(new MaddeningCacophonyEffect()); + } + + private MaddeningCacophony(final MaddeningCacophony card) { + super(card); + } + + @Override + public MaddeningCacophony copy() { + return new MaddeningCacophony(this); + } +} + +class MaddeningCacophonyEffect extends OneShotEffect { + + MaddeningCacophonyEffect() { + super(Outcome.Benefit); + staticText = "each opponent mills eight cards. If this spell was kicked, " + + "instead each opponent mills half their library, rounded up"; + } + + private MaddeningCacophonyEffect(final MaddeningCacophonyEffect effect) { + super(effect); + } + + @Override + public MaddeningCacophonyEffect copy() { + return new MaddeningCacophonyEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + boolean kicked = KickedCondition.instance.apply(game, source); + for (UUID playerId : game.getOpponents(source.getControllerId())) { + Player player = game.getPlayer(playerId); + if (player == null) { + continue; + } + int toMill = 8; + if (kicked) { + toMill = (int) Math.ceil(player.getLibrary().size() / 2); + } + player.millCards(toMill, source, game); + } + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/ZendikarRising.java b/Mage.Sets/src/mage/sets/ZendikarRising.java index 0ebbe0590e1..97d72244c3a 100644 --- a/Mage.Sets/src/mage/sets/ZendikarRising.java +++ b/Mage.Sets/src/mage/sets/ZendikarRising.java @@ -196,6 +196,7 @@ public final class ZendikarRising extends ExpansionSet { cards.add(new SetCardInfo("Lullmage's Domination", 66, Rarity.UNCOMMON, mage.cards.l.LullmagesDomination.class)); cards.add(new SetCardInfo("Lullmage's Familiar", 227, Rarity.UNCOMMON, mage.cards.l.LullmagesFamiliar.class)); cards.add(new SetCardInfo("Luminarch Aspirant", 24, Rarity.RARE, mage.cards.l.LuminarchAspirant.class)); + cards.add(new SetCardInfo("Maddening Cacophony", 67, Rarity.RARE, mage.cards.m.MaddeningCacophony.class)); cards.add(new SetCardInfo("Magmatic Channeler", 148, Rarity.RARE, mage.cards.m.MagmaticChanneler.class)); cards.add(new SetCardInfo("Makindi Mesas", 26, Rarity.UNCOMMON, mage.cards.m.MakindiMesas.class)); cards.add(new SetCardInfo("Makindi Ox", 25, Rarity.COMMON, mage.cards.m.MakindiOx.class));