diff --git a/Mage.Sets/src/mage/cards/f/FrenziedArynx.java b/Mage.Sets/src/mage/cards/f/FrenziedArynx.java new file mode 100644 index 00000000000..26ceb3e0ca3 --- /dev/null +++ b/Mage.Sets/src/mage/cards/f/FrenziedArynx.java @@ -0,0 +1,51 @@ +package mage.cards.f; + +import mage.MageInt; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.continuous.BoostSourceEffect; +import mage.abilities.keyword.RiotAbility; +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 java.util.UUID; + +/** + * @author TheElk801 + */ +public final class FrenziedArynx extends CardImpl { + + public FrenziedArynx(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{R}{G}"); + + this.subtype.add(SubType.CAT); + this.subtype.add(SubType.BEAST); + this.power = new MageInt(3); + this.toughness = new MageInt(3); + + // Riot + this.addAbility(new RiotAbility()); + + // Trample + this.addAbility(TrampleAbility.getInstance()); + + // {4}{R}{G}: Frenzied Arynx gets +3/+0 until end of turn. + this.addAbility(new SimpleActivatedAbility( + new BoostSourceEffect(3, 0, Duration.EndOfTurn), + new ManaCostsImpl("{4}{R}{G}") + )); + } + + public FrenziedArynx(final FrenziedArynx card) { + super(card); + } + + @Override + public FrenziedArynx copy() { + return new FrenziedArynx(this); + } +} diff --git a/Mage.Sets/src/mage/sets/RavnicaAllegiance.java b/Mage.Sets/src/mage/sets/RavnicaAllegiance.java index f32681bae00..8b65d36b12f 100644 --- a/Mage.Sets/src/mage/sets/RavnicaAllegiance.java +++ b/Mage.Sets/src/mage/sets/RavnicaAllegiance.java @@ -34,6 +34,7 @@ public final class RavnicaAllegiance extends ExpansionSet { cards.add(new SetCardInfo("Aeromunculus", 152, Rarity.COMMON, mage.cards.a.Aeromunculus.class)); cards.add(new SetCardInfo("Bedevil", 157, Rarity.RARE, mage.cards.b.Bedevil.class)); + cards.add(new SetCardInfo("Frenzied Arynx", 173, Rarity.COMMON, mage.cards.f.FrenziedArynx.class)); cards.add(new SetCardInfo("Gate Colossus", 232, Rarity.UNCOMMON, mage.cards.g.GateColossus.class)); cards.add(new SetCardInfo("Growth Spiral", 178, Rarity.COMMON, mage.cards.g.GrowthSpiral.class)); cards.add(new SetCardInfo("Imperious Oligarch", 184, Rarity.COMMON, mage.cards.i.ImperiousOligarch.class)); diff --git a/Mage/src/main/java/mage/abilities/keyword/RiotAbility.java b/Mage/src/main/java/mage/abilities/keyword/RiotAbility.java new file mode 100644 index 00000000000..47ca943dcb7 --- /dev/null +++ b/Mage/src/main/java/mage/abilities/keyword/RiotAbility.java @@ -0,0 +1,96 @@ + +package mage.abilities.keyword; + +import mage.abilities.Ability; +import mage.abilities.Mode; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.effects.ReplacementEffectImpl; +import mage.abilities.effects.common.continuous.GainAbilitySourceEffect; +import mage.constants.Duration; +import mage.constants.Outcome; +import mage.constants.Zone; +import mage.counters.CounterType; +import mage.game.Game; +import mage.game.events.EntersTheBattlefieldEvent; +import mage.game.events.GameEvent; +import mage.game.events.GameEvent.EventType; +import mage.game.permanent.Permanent; +import mage.players.Player; + +/** + * @author TheElk801 + */ +public class RiotAbility extends SimpleStaticAbility { + + public RiotAbility() { + super(Zone.ALL, new RiotReplacementEffect()); + } + + private RiotAbility(final RiotAbility ability) { + super(ability); + } + + @Override + public RiotAbility copy() { + return new RiotAbility(this); + } + + @Override + public String getRule() { + return "Riot (This creature enters the battlefield with your choice of a +1/+1 counter or haste.)"; + } +} + +class RiotReplacementEffect extends ReplacementEffectImpl { + + RiotReplacementEffect() { + super(Duration.EndOfGame, Outcome.Detriment); + } + + private RiotReplacementEffect(final RiotReplacementEffect effect) { + super(effect); + } + + @Override + public boolean checksEventType(GameEvent event, Game game) { + return event.getType() == EventType.ENTERS_THE_BATTLEFIELD; + } + + @Override + public boolean applies(GameEvent event, Ability source, Game game) { + return event.getTargetId().equals(source.getSourceId()); + } + + @Override + public boolean apply(Game game, Ability source) { + return false; + } + + @Override + public boolean replaceEvent(GameEvent event, Ability source, Game game) { + Permanent creature = ((EntersTheBattlefieldEvent) event).getTarget(); + Player controller = game.getPlayer(source.getControllerId()); + if (creature != null && controller != null) { + if (controller.chooseUse(outcome, "Have " + creature.getLogName() + " enter the battlefield with a +1/+1 counter on it? (If you don't it has haste)", source, game)) { + if (!game.isSimulation()) { + game.informPlayers(controller.getLogName() + " choose to put a +1/+1 counter on " + creature.getName()); + } + creature.addCounters(CounterType.P1P1.createInstance(), source, game, event.getAppliedEffects()); + } else { + game.addEffect(new GainAbilitySourceEffect(HasteAbility.getInstance(), Duration.Custom), source); + } + } + return false; + } + + @Override + public String getText(Mode mode) { + return staticText; + } + + @Override + public RiotReplacementEffect copy() { + return new RiotReplacementEffect(this); + } + +} \ No newline at end of file diff --git a/Utils/keywords.txt b/Utils/keywords.txt index bef1ffec8ac..f32a5b30284 100644 --- a/Utils/keywords.txt +++ b/Utils/keywords.txt @@ -76,6 +76,7 @@ Prowess|new| Reach|instance| Rebound|new| Renown|number| +Riot|new| Scavenge|cost| Shadow|instance| Shroud|instance|