From 7ca32d5bc3de5398854604acfebb31eccc4c1528 Mon Sep 17 00:00:00 2001 From: Susucre <34709007+Susucre@users.noreply.github.com> Date: Fri, 18 Jul 2025 18:24:48 +0200 Subject: [PATCH] implement [EOE] Cloudsculpt Technician --- .../mage/cards/c/CloudsculptTechnician.java | 55 +++++++++++++++++++ Mage.Sets/src/mage/sets/EdgeOfEternities.java | 1 + 2 files changed, 56 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/c/CloudsculptTechnician.java diff --git a/Mage.Sets/src/mage/cards/c/CloudsculptTechnician.java b/Mage.Sets/src/mage/cards/c/CloudsculptTechnician.java new file mode 100644 index 00000000000..f4eceed3997 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/CloudsculptTechnician.java @@ -0,0 +1,55 @@ + +package mage.cards.c; + +import mage.MageInt; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.condition.Condition; +import mage.abilities.condition.common.PermanentsOnTheBattlefieldCondition; +import mage.abilities.decorator.ConditionalContinuousEffect; +import mage.abilities.effects.common.continuous.BoostSourceEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.filter.StaticFilters; + +import java.util.UUID; + +/** + * @author Susucr + */ +public final class CloudsculptTechnician extends CardImpl { + + private static final Condition condition = + new PermanentsOnTheBattlefieldCondition(StaticFilters.FILTER_CONTROLLED_PERMANENT_ARTIFACT); + + public CloudsculptTechnician(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{U}"); + this.subtype.add(SubType.JELLYFISH); + this.subtype.add(SubType.ARTIFICER); + this.power = new MageInt(1); + this.toughness = new MageInt(4); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // As long as you control an artifact, this creature gets +1/+0. + this.addAbility(new SimpleStaticAbility( + new ConditionalContinuousEffect( + new BoostSourceEffect(1, 0, Duration.WhileOnBattlefield), + condition, "As long as you control an artifact, this creature gets +1/+0" + ) + )); + } + + private CloudsculptTechnician(final CloudsculptTechnician card) { + super(card); + } + + @Override + public CloudsculptTechnician copy() { + return new CloudsculptTechnician(this); + } +} diff --git a/Mage.Sets/src/mage/sets/EdgeOfEternities.java b/Mage.Sets/src/mage/sets/EdgeOfEternities.java index b28374b8293..5e9262eb145 100644 --- a/Mage.Sets/src/mage/sets/EdgeOfEternities.java +++ b/Mage.Sets/src/mage/sets/EdgeOfEternities.java @@ -63,6 +63,7 @@ public final class EdgeOfEternities extends ExpansionSet { cards.add(new SetCardInfo("Chorale of the Void", 331, Rarity.RARE, mage.cards.c.ChoraleOfTheVoid.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Chorale of the Void", 91, Rarity.RARE, mage.cards.c.ChoraleOfTheVoid.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Chrome Companion", 236, Rarity.COMMON, mage.cards.c.ChromeCompanion.class)); + cards.add(new SetCardInfo("Cloudsqculpt Technician", 49, Rarity.COMMON, mage.cards.c.CloudsculptTechnician.class)); cards.add(new SetCardInfo("Codecracker Hound", 50, Rarity.UNCOMMON, mage.cards.c.CodecrackerHound.class)); cards.add(new SetCardInfo("Command Bridge", 252, Rarity.COMMON, mage.cards.c.CommandBridge.class)); cards.add(new SetCardInfo("Consult the Star Charts", 325, Rarity.RARE, mage.cards.c.ConsultTheStarCharts.class, NON_FULL_USE_VARIOUS));