From a6afbbdc019f07344022185f7b47fd6004303283 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Wed, 19 Jun 2024 07:30:03 -0400 Subject: [PATCH] [ACR] Implement Basim Ibn Ishaq --- Mage.Sets/src/mage/cards/b/BasimIbnIshaq.java | 63 +++++++++++++++++++ Mage.Sets/src/mage/sets/AssassinsCreed.java | 1 + 2 files changed, 64 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/b/BasimIbnIshaq.java diff --git a/Mage.Sets/src/mage/cards/b/BasimIbnIshaq.java b/Mage.Sets/src/mage/cards/b/BasimIbnIshaq.java new file mode 100644 index 00000000000..db0401f479b --- /dev/null +++ b/Mage.Sets/src/mage/cards/b/BasimIbnIshaq.java @@ -0,0 +1,63 @@ +package mage.cards.b; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.DealsCombatDamageToAPlayerTriggeredAbility; +import mage.abilities.common.SpellCastControllerTriggeredAbility; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.combat.CantBeBlockedSourceEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.counters.CounterType; +import mage.filter.FilterSpell; +import mage.filter.predicate.mageobject.HistoricPredicate; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class BasimIbnIshaq extends CardImpl { + + private static final FilterSpell filter = new FilterSpell("a historic spell"); + + static { + filter.add(HistoricPredicate.instance); + } + + public BasimIbnIshaq(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{U}{B}"); + + this.supertype.add(SuperType.LEGENDARY); + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.ASSASSIN); + this.power = new MageInt(2); + this.toughness = new MageInt(2); + + // Whenever you cast a historic spell, draw a card. Basim Ibn Ishaq can't be blocked this turn. This ability triggers only once each turn. + Ability ability = new SpellCastControllerTriggeredAbility( + new DrawCardSourceControllerEffect(1), filter, false + ).setTriggersLimitEachTurn(1); + ability.addEffect(new CantBeBlockedSourceEffect(Duration.EndOfTurn)); + this.addAbility(ability); + + // Whenever Basim Ibn Ishaq deals combat damage to a player, put a +1/+1 counter on it. + this.addAbility(new DealsCombatDamageToAPlayerTriggeredAbility( + new AddCountersSourceEffect(CounterType.P1P1.createInstance()) + )); + } + + private BasimIbnIshaq(final BasimIbnIshaq card) { + super(card); + } + + @Override + public BasimIbnIshaq copy() { + return new BasimIbnIshaq(this); + } +} diff --git a/Mage.Sets/src/mage/sets/AssassinsCreed.java b/Mage.Sets/src/mage/sets/AssassinsCreed.java index 9c24462b10c..ef0ba62c787 100644 --- a/Mage.Sets/src/mage/sets/AssassinsCreed.java +++ b/Mage.Sets/src/mage/sets/AssassinsCreed.java @@ -22,6 +22,7 @@ public final class AssassinsCreed extends ExpansionSet { this.hasBoosters = false; cards.add(new SetCardInfo("Assassin's Trophy", 166, Rarity.RARE, mage.cards.a.AssassinsTrophy.class)); + cards.add(new SetCardInfo("Basim Ibn Ishaq", 49, Rarity.RARE, mage.cards.b.BasimIbnIshaq.class)); cards.add(new SetCardInfo("Cathartic Reunion", 94, Rarity.UNCOMMON, mage.cards.c.CatharticReunion.class)); cards.add(new SetCardInfo("Cleopatra, Exiled Pharaoh", 52, Rarity.MYTHIC, mage.cards.c.CleopatraExiledPharaoh.class)); cards.add(new SetCardInfo("Coastal Piracy", 84, Rarity.UNCOMMON, mage.cards.c.CoastalPiracy.class));