From 099a80f99786b925765acd4f1d4413c78687068f Mon Sep 17 00:00:00 2001 From: theelk801 Date: Wed, 1 Nov 2023 22:04:21 -0400 Subject: [PATCH] [LCC] Implement Order of Sacred Dusk --- .../src/mage/cards/o/OrderOfSacredDusk.java | 60 +++++++++++++++++++ .../sets/LostCavernsOfIxalanCommander.java | 1 + 2 files changed, 61 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/o/OrderOfSacredDusk.java diff --git a/Mage.Sets/src/mage/cards/o/OrderOfSacredDusk.java b/Mage.Sets/src/mage/cards/o/OrderOfSacredDusk.java new file mode 100644 index 00000000000..9d609de5cf9 --- /dev/null +++ b/Mage.Sets/src/mage/cards/o/OrderOfSacredDusk.java @@ -0,0 +1,60 @@ +package mage.cards.o; + +import mage.MageInt; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.effects.common.continuous.GainAbilityControlledEffect; +import mage.abilities.keyword.*; +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 java.util.UUID; + +/** + * @author TheElk801 + */ +public final class OrderOfSacredDusk extends CardImpl { + + private static final FilterPermanent filter = new FilterPermanent(SubType.VAMPIRE, "Vampires"); + + public OrderOfSacredDusk(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{6}{W}{B}"); + + this.subtype.add(SubType.VAMPIRE); + this.subtype.add(SubType.KNIGHT); + this.power = new MageInt(5); + this.toughness = new MageInt(5); + + // Convoke + this.addAbility(new ConvokeAbility()); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Lifelink + this.addAbility(LifelinkAbility.getInstance()); + + // Haste + this.addAbility(HasteAbility.getInstance()); + + // Exalted + this.addAbility(new ExaltedAbility()); + + // Other Vampires you control have exalted. + this.addAbility(new SimpleStaticAbility(new GainAbilityControlledEffect( + new ExaltedAbility(), Duration.WhileOnBattlefield, filter, true + ))); + } + + private OrderOfSacredDusk(final OrderOfSacredDusk card) { + super(card); + } + + @Override + public OrderOfSacredDusk copy() { + return new OrderOfSacredDusk(this); + } +} diff --git a/Mage.Sets/src/mage/sets/LostCavernsOfIxalanCommander.java b/Mage.Sets/src/mage/sets/LostCavernsOfIxalanCommander.java index 941b5a321b2..f8ea0dda477 100644 --- a/Mage.Sets/src/mage/sets/LostCavernsOfIxalanCommander.java +++ b/Mage.Sets/src/mage/sets/LostCavernsOfIxalanCommander.java @@ -35,6 +35,7 @@ public final class LostCavernsOfIxalanCommander extends ExpansionSet { cards.add(new SetCardInfo("Lightning Greaves", 114, Rarity.UNCOMMON, mage.cards.l.LightningGreaves.class)); cards.add(new SetCardInfo("Mimic Vat", 115, Rarity.RARE, mage.cards.m.MimicVat.class)); cards.add(new SetCardInfo("Mist Dancer", 76, Rarity.RARE, mage.cards.m.MistDancer.class)); + cards.add(new SetCardInfo("Order of Sacred Dusk", 97, Rarity.RARE, mage.cards.o.OrderOfSacredDusk.class)); cards.add(new SetCardInfo("Path of Ancestry", 346, Rarity.COMMON, mage.cards.p.PathOfAncestry.class)); cards.add(new SetCardInfo("Strionic Resonator", 116, Rarity.RARE, mage.cards.s.StrionicResonator.class)); cards.add(new SetCardInfo("Temple Bell", 117, Rarity.RARE, mage.cards.t.TempleBell.class));