From 791c67aae2e4a7d604239359416adfc0cd2336ca Mon Sep 17 00:00:00 2001 From: theelk801 Date: Sun, 11 May 2025 20:46:12 -0400 Subject: [PATCH] [FIN] Implement Absolute Virtue --- .../src/mage/cards/a/AbsoluteVirtue.java | 85 +++++++++++++++++++ Mage.Sets/src/mage/sets/FinalFantasy.java | 2 + 2 files changed, 87 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/a/AbsoluteVirtue.java diff --git a/Mage.Sets/src/mage/cards/a/AbsoluteVirtue.java b/Mage.Sets/src/mage/cards/a/AbsoluteVirtue.java new file mode 100644 index 00000000000..ac78f6fcc7e --- /dev/null +++ b/Mage.Sets/src/mage/cards/a/AbsoluteVirtue.java @@ -0,0 +1,85 @@ +package mage.cards.a; + +import mage.MageInt; +import mage.MageItem; +import mage.MageObject; +import mage.abilities.common.CantBeCounteredSourceAbility; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.effects.common.continuous.GainAbilityControllerEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.keyword.ProtectionAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.filter.StaticFilters; +import mage.game.Game; + +import java.util.Optional; +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class AbsoluteVirtue extends CardImpl { + + public AbsoluteVirtue(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{6}{W}{U}"); + + this.supertype.add(SuperType.LEGENDARY); + this.subtype.add(SubType.AVATAR); + this.subtype.add(SubType.WARRIOR); + this.power = new MageInt(8); + this.toughness = new MageInt(8); + + // This spell can't be countered. + this.addAbility(new CantBeCounteredSourceAbility()); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // You have protection from each of your opponents. + this.addAbility(new SimpleStaticAbility(new GainAbilityControllerEffect(new AbsoluteVirtueAbility()))); + } + + private AbsoluteVirtue(final AbsoluteVirtue card) { + super(card); + } + + @Override + public AbsoluteVirtue copy() { + return new AbsoluteVirtue(this); + } +} + +class AbsoluteVirtueAbility extends ProtectionAbility { + + public AbsoluteVirtueAbility() { + super(StaticFilters.FILTER_CARD); + } + + private AbsoluteVirtueAbility(final AbsoluteVirtueAbility ability) { + super(ability); + } + + @Override + public AbsoluteVirtueAbility copy() { + return new AbsoluteVirtueAbility(this); + } + + @Override + public String getRule() { + return "protection from each of your opponents"; + } + + @Override + public boolean canTarget(MageObject source, Game game) { + return Optional + .ofNullable(source) + .map(MageItem::getId) + .map(game::getControllerId) + .map(uuid -> !game.getOpponents(this.getControllerId()).contains(uuid)) + .orElse(true); + } +} diff --git a/Mage.Sets/src/mage/sets/FinalFantasy.java b/Mage.Sets/src/mage/sets/FinalFantasy.java index 838d1c998e9..1d9f46ac31d 100644 --- a/Mage.Sets/src/mage/sets/FinalFantasy.java +++ b/Mage.Sets/src/mage/sets/FinalFantasy.java @@ -22,6 +22,8 @@ public final class FinalFantasy extends ExpansionSet { cards.add(new SetCardInfo("A Realm Reborn", 196, Rarity.RARE, mage.cards.a.ARealmReborn.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("A Realm Reborn", 344, Rarity.RARE, mage.cards.a.ARealmReborn.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Absolute Virtue", 212, Rarity.MYTHIC, mage.cards.a.AbsoluteVirtue.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Absolute Virtue", 476, Rarity.MYTHIC, mage.cards.a.AbsoluteVirtue.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Adventurer's Inn", 271, Rarity.COMMON, mage.cards.a.AdventurersInn.class)); cards.add(new SetCardInfo("Aerith Gainsborough", 4, Rarity.RARE, mage.cards.a.AerithGainsborough.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Aerith Gainsborough", 374, Rarity.RARE, mage.cards.a.AerithGainsborough.class, NON_FULL_USE_VARIOUS));