diff --git a/Mage.Sets/src/mage/cards/d/DraconauticsEngineer.java b/Mage.Sets/src/mage/cards/d/DraconauticsEngineer.java new file mode 100644 index 00000000000..164d68c159c --- /dev/null +++ b/Mage.Sets/src/mage/cards/d/DraconauticsEngineer.java @@ -0,0 +1,55 @@ +package mage.cards.d; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.effects.common.continuous.GainAbilityControlledEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.ExhaustAbility; +import mage.abilities.keyword.HasteAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.counters.CounterType; +import mage.filter.StaticFilters; +import mage.game.permanent.token.DinDragonToken; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class DraconauticsEngineer extends CardImpl { + + public DraconauticsEngineer(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{R}"); + + this.subtype.add(SubType.GOBLIN); + this.subtype.add(SubType.ARTIFICER); + this.power = new MageInt(2); + this.toughness = new MageInt(2); + + // Exhaust -- {R}: Other creatures you control gain haste until end of turn. Put a +1/+1 counter on this creature. + Ability ability = new ExhaustAbility(new GainAbilityControlledEffect( + HasteAbility.getInstance(), Duration.EndOfTurn, + StaticFilters.FILTER_PERMANENT_CREATURES, true + ), new ManaCostsImpl<>("{R}")); + ability.addEffect(new AddCountersSourceEffect(CounterType.P1P1.createInstance())); + this.addAbility(ability); + + // Exhaust -- {3}{R}: Create a 4/4 red Dinosaur Dragon creature token with flying. + this.addAbility(new ExhaustAbility(new CreateTokenEffect(new DinDragonToken()), new ManaCostsImpl<>("{3}{R}"))); + } + + private DraconauticsEngineer(final DraconauticsEngineer card) { + super(card); + } + + @Override + public DraconauticsEngineer copy() { + return new DraconauticsEngineer(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Aetherdrift.java b/Mage.Sets/src/mage/sets/Aetherdrift.java index b73ef3325d5..a7f50c41c67 100644 --- a/Mage.Sets/src/mage/sets/Aetherdrift.java +++ b/Mage.Sets/src/mage/sets/Aetherdrift.java @@ -51,6 +51,7 @@ public final class Aetherdrift extends ExpansionSet { cards.add(new SetCardInfo("Daretti, Rocketeer Engineer", 120, Rarity.RARE, mage.cards.d.DarettiRocketeerEngineer.class)); cards.add(new SetCardInfo("Dismal Backwater", 254, Rarity.COMMON, mage.cards.d.DismalBackwater.class)); cards.add(new SetCardInfo("District Mascot", 158, Rarity.RARE, mage.cards.d.DistrictMascot.class)); + cards.add(new SetCardInfo("Draconautics Engineer", 121, Rarity.RARE, mage.cards.d.DraconauticsEngineer.class)); cards.add(new SetCardInfo("Dredger's Insight", 159, Rarity.UNCOMMON, mage.cards.d.DredgersInsight.class)); cards.add(new SetCardInfo("Earthrumbler", 160, Rarity.UNCOMMON, mage.cards.e.Earthrumbler.class)); cards.add(new SetCardInfo("Embalmed Ascendant", 201, Rarity.UNCOMMON, mage.cards.e.EmbalmedAscendant.class)); diff --git a/Mage/src/main/java/mage/game/permanent/token/DinDragonToken.java b/Mage/src/main/java/mage/game/permanent/token/DinDragonToken.java new file mode 100644 index 00000000000..c833b1d4418 --- /dev/null +++ b/Mage/src/main/java/mage/game/permanent/token/DinDragonToken.java @@ -0,0 +1,31 @@ +package mage.game.permanent.token; + +import mage.MageInt; +import mage.abilities.keyword.FlyingAbility; +import mage.constants.CardType; +import mage.constants.SubType; + +/** + * @author TheElk801 + */ +public final class DinDragonToken extends TokenImpl { + + public DinDragonToken() { + super("Dragon Token", "4/4 red Dinosaur Dragon creature token with flying"); + cardType.add(CardType.CREATURE); + color.setRed(true); + subtype.add(SubType.DINOSAUR); + subtype.add(SubType.DRAGON); + power = new MageInt(4); + toughness = new MageInt(4); + addAbility(FlyingAbility.getInstance()); + } + + private DinDragonToken(final DinDragonToken token) { + super(token); + } + + public DinDragonToken copy() { + return new DinDragonToken(this); + } +}