diff --git a/Mage.Sets/src/mage/cards/d/DefenestratedPhantom.java b/Mage.Sets/src/mage/cards/d/DefenestratedPhantom.java new file mode 100644 index 00000000000..0c07677aaac --- /dev/null +++ b/Mage.Sets/src/mage/cards/d/DefenestratedPhantom.java @@ -0,0 +1,41 @@ +package mage.cards.d; + +import mage.MageInt; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.keyword.DisguiseAbility; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class DefenestratedPhantom extends CardImpl { + + public DefenestratedPhantom(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{4}{W}{W}"); + + this.subtype.add(SubType.SPIRIT); + this.power = new MageInt(4); + this.toughness = new MageInt(3); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Disguise {4}{W} + this.addAbility(new DisguiseAbility(this, new ManaCostsImpl<>("{4}{W}"))); + } + + private DefenestratedPhantom(final DefenestratedPhantom card) { + super(card); + } + + @Override + public DefenestratedPhantom copy() { + return new DefenestratedPhantom(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java b/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java index 7a5b3c924f0..f4f4af79988 100644 --- a/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java +++ b/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java @@ -36,6 +36,7 @@ public final class MurdersAtKarlovManor extends ExpansionSet { cards.add(new SetCardInfo("Crime Novelist", 121, Rarity.UNCOMMON, mage.cards.c.CrimeNovelist.class)); cards.add(new SetCardInfo("Curious Cadaver", 194, Rarity.UNCOMMON, mage.cards.c.CuriousCadaver.class)); cards.add(new SetCardInfo("Deduce", 52, Rarity.COMMON, mage.cards.d.Deduce.class)); + cards.add(new SetCardInfo("Defenestrated Phantom", 11, Rarity.COMMON, mage.cards.d.DefenestratedPhantom.class)); cards.add(new SetCardInfo("Demand Answers", 122, Rarity.COMMON, mage.cards.d.DemandAnswers.class)); cards.add(new SetCardInfo("Elegant Parlor", 260, Rarity.RARE, mage.cards.e.ElegantParlor.class)); cards.add(new SetCardInfo("Fanatical Strength", 159, Rarity.COMMON, mage.cards.f.FanaticalStrength.class)); diff --git a/Mage/src/main/java/mage/abilities/keyword/DisguiseAbility.java b/Mage/src/main/java/mage/abilities/keyword/DisguiseAbility.java new file mode 100644 index 00000000000..629ac59f895 --- /dev/null +++ b/Mage/src/main/java/mage/abilities/keyword/DisguiseAbility.java @@ -0,0 +1,31 @@ +package mage.abilities.keyword; + +import mage.abilities.SpellAbility; +import mage.abilities.costs.Cost; +import mage.abilities.costs.mana.GenericManaCost; +import mage.cards.Card; + +/** + * @author TheElk801 + * TODO: Implement this + */ +public class DisguiseAbility extends SpellAbility { + + public DisguiseAbility(Card card, Cost disguiseCost) { + super(new GenericManaCost(3), card.getName()); + } + + private DisguiseAbility(final DisguiseAbility ability) { + super(ability); + } + + @Override + public DisguiseAbility copy() { + return new DisguiseAbility(this); + } + + @Override + public String getRule() { + return "Disguise"; + } +} diff --git a/Utils/keywords.txt b/Utils/keywords.txt index 5c52f43ce68..02f7e59008a 100644 --- a/Utils/keywords.txt +++ b/Utils/keywords.txt @@ -29,6 +29,7 @@ Delve|new| Dethrone|new| Devoid|color| Defender|instance| +Disguise|card, cost| Disturb|cost| Dredge|number| Doctor's companion|instance|