From bb0724728257356932b8a90449600d2b095022dd Mon Sep 17 00:00:00 2001 From: theelk801 Date: Mon, 24 Mar 2025 11:10:39 -0400 Subject: [PATCH] [TDM] Implement Channeled Dragonfire and add skip list for harmonize --- .../src/mage/cards/c/ChanneledDragonfire.java | 36 +++++++++++++++++++ .../src/mage/sets/TarkirDragonstorm.java | 7 ++++ .../abilities/keyword/HarmonizeAbility.java | 27 ++++++++++++++ Utils/keywords.txt | 1 + 4 files changed, 71 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/c/ChanneledDragonfire.java create mode 100644 Mage/src/main/java/mage/abilities/keyword/HarmonizeAbility.java diff --git a/Mage.Sets/src/mage/cards/c/ChanneledDragonfire.java b/Mage.Sets/src/mage/cards/c/ChanneledDragonfire.java new file mode 100644 index 00000000000..adc69cb80f5 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/ChanneledDragonfire.java @@ -0,0 +1,36 @@ +package mage.cards.c; + +import mage.abilities.effects.common.DamageTargetEffect; +import mage.abilities.keyword.HarmonizeAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.target.common.TargetAnyTarget; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class ChanneledDragonfire extends CardImpl { + + public ChanneledDragonfire(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{R}"); + + // Channeled Dragonfire deals 2 damage to any target. + this.getSpellAbility().addEffect(new DamageTargetEffect(2)); + this.getSpellAbility().addTarget(new TargetAnyTarget()); + + // Harmonize {5}{R}{R} + this.addAbility(new HarmonizeAbility(this, "{5}{R}{R}")); + } + + private ChanneledDragonfire(final ChanneledDragonfire card) { + super(card); + } + + @Override + public ChanneledDragonfire copy() { + return new ChanneledDragonfire(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java index c7fbf709177..7b24594acd1 100644 --- a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java +++ b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java @@ -4,11 +4,15 @@ import mage.cards.ExpansionSet; import mage.constants.Rarity; import mage.constants.SetType; +import java.util.Arrays; +import java.util.List; + /** * @author TheElk801 */ public final class TarkirDragonstorm extends ExpansionSet { + private static final List unfinished = Arrays.asList("Channeled Dragonfire", "Roamer's Routine", "Ureni's Rebuff", "Winternight Stories"); private static final TarkirDragonstorm instance = new TarkirDragonstorm(); public static TarkirDragonstorm getInstance() { @@ -36,6 +40,7 @@ public final class TarkirDragonstorm extends ExpansionSet { cards.add(new SetCardInfo("Bone-Cairn Butcher", 173, Rarity.UNCOMMON, mage.cards.b.BoneCairnButcher.class)); cards.add(new SetCardInfo("Boulderborn Dragon", 239, Rarity.COMMON, mage.cards.b.BoulderbornDragon.class)); cards.add(new SetCardInfo("Caustic Exhale", 74, Rarity.COMMON, mage.cards.c.CausticExhale.class)); + cards.add(new SetCardInfo("Channeled Dragonfire", 423, Rarity.UNCOMMON, mage.cards.c.ChanneledDragonfire.class)); cards.add(new SetCardInfo("Coordinated Maneuver", 6, Rarity.COMMON, mage.cards.c.CoordinatedManeuver.class)); cards.add(new SetCardInfo("Cori Mountain Stalwart", 175, Rarity.UNCOMMON, mage.cards.c.CoriMountainStalwart.class)); cards.add(new SetCardInfo("Cori-Steel Cutter", 103, Rarity.RARE, mage.cards.c.CoriSteelCutter.class)); @@ -117,5 +122,7 @@ public final class TarkirDragonstorm extends ExpansionSet { cards.add(new SetCardInfo("Voice of Victory", 33, Rarity.RARE, mage.cards.v.VoiceOfVictory.class)); cards.add(new SetCardInfo("Watcher of the Wayside", 249, Rarity.COMMON, mage.cards.w.WatcherOfTheWayside.class)); cards.add(new SetCardInfo("Wind-Scarred Crag", 271, Rarity.COMMON, mage.cards.w.WindScarredCrag.class)); + + cards.removeIf(setCardInfo -> unfinished.contains(setCardInfo.getName())); } } diff --git a/Mage/src/main/java/mage/abilities/keyword/HarmonizeAbility.java b/Mage/src/main/java/mage/abilities/keyword/HarmonizeAbility.java new file mode 100644 index 00000000000..92f6310401c --- /dev/null +++ b/Mage/src/main/java/mage/abilities/keyword/HarmonizeAbility.java @@ -0,0 +1,27 @@ +package mage.abilities.keyword; + +import mage.abilities.SpellAbility; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.cards.Card; +import mage.constants.Zone; + +/** + * TODO: Implement this + * + * @author TheElk801 + */ +public class HarmonizeAbility extends SpellAbility { + + public HarmonizeAbility(Card card, String manaString) { + super(new ManaCostsImpl<>(manaString), card.getName(), Zone.GRAVEYARD); + } + + private HarmonizeAbility(final HarmonizeAbility ability) { + super(ability); + } + + @Override + public HarmonizeAbility copy() { + return new HarmonizeAbility(this); + } +} diff --git a/Utils/keywords.txt b/Utils/keywords.txt index a55b9e603d9..a3eea683be2 100644 --- a/Utils/keywords.txt +++ b/Utils/keywords.txt @@ -63,6 +63,7 @@ For Mirrodin!|new| Freerunning|manaString| Friends forever|instance| Gift|card| +Harmonize|card, manaString| Haste|instance| Hexproof|instance| Hideaway|number|