From cf3b3cbb76b60bd85fb0f8b6d78b6dc3c91b805a Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 8 Apr 2021 17:21:41 -0400 Subject: [PATCH] [C21] Implemented Archaeomancer's Map --- .../src/mage/cards/a/ArchaeomancersMap.java | 81 +++++++++++++++++++ .../src/mage/sets/Commander2021Edition.java | 1 + .../EntersBattlefieldAllTriggeredAbility.java | 1 + 3 files changed, 83 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/a/ArchaeomancersMap.java diff --git a/Mage.Sets/src/mage/cards/a/ArchaeomancersMap.java b/Mage.Sets/src/mage/cards/a/ArchaeomancersMap.java new file mode 100644 index 00000000000..39918d13917 --- /dev/null +++ b/Mage.Sets/src/mage/cards/a/ArchaeomancersMap.java @@ -0,0 +1,81 @@ +package mage.cards.a; + +import mage.abilities.Ability; +import mage.abilities.common.EntersBattlefieldAllTriggeredAbility; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.condition.Condition; +import mage.abilities.decorator.ConditionalInterveningIfTriggeredAbility; +import mage.abilities.effects.common.PutCardFromHandOntoBattlefieldEffect; +import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.constants.TargetController; +import mage.filter.FilterCard; +import mage.filter.FilterPermanent; +import mage.filter.StaticFilters; +import mage.filter.common.FilterLandPermanent; +import mage.game.Game; +import mage.target.common.TargetCardInLibrary; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class ArchaeomancersMap extends CardImpl { + + private static final FilterCard filter = new FilterCard("basic Plains cards"); + private static final FilterPermanent filter2 = new FilterLandPermanent(); + + static { + filter.add(SubType.PLAINS.getPredicate()); + filter.add(SuperType.BASIC.getPredicate()); + filter2.add(TargetController.OPPONENT.getControllerPredicate()); + } + + public ArchaeomancersMap(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{2}{W}"); + + // When Archaeomancer's Map enters the battlefield, search your library for up to two basic Plains cards, reveal them, put them into your hand, then shuffle. + this.addAbility(new EntersBattlefieldTriggeredAbility( + new SearchLibraryPutInHandEffect(new TargetCardInLibrary(2, filter), true) + )); + + // Whenever a land enters the battlefield under an opponent's control, if that player controls more lands than you, you may put a land card from your hand onto the battlefield. + this.addAbility(new ConditionalInterveningIfTriggeredAbility( + new EntersBattlefieldAllTriggeredAbility( + new PutCardFromHandOntoBattlefieldEffect(StaticFilters.FILTER_CARD_LAND_A), filter2 + ), ArchaeomancersMapCondition.instance, "Whenever a land enters the battlefield " + + "under an opponent's control, if that player controls more lands than you, " + + "you may put a land card from your hand onto the battlefield." + )); + } + + private ArchaeomancersMap(final ArchaeomancersMap card) { + super(card); + } + + @Override + public ArchaeomancersMap copy() { + return new ArchaeomancersMap(this); + } +} + +enum ArchaeomancersMapCondition implements Condition { + instance; + + @Override + public boolean apply(Game game, Ability source) { + UUID playerId = (UUID) source.getEffects().get(0).getValue("permanentEnteringControllerId"); + return playerId != null && game.getBattlefield().count( + StaticFilters.FILTER_CONTROLLED_PERMANENT_LAND, + source.getSourceId(), playerId, game + ) > game.getBattlefield().count( + StaticFilters.FILTER_CONTROLLED_PERMANENT_LAND, + source.getSourceId(), source.getControllerId(), game + ); + } +} diff --git a/Mage.Sets/src/mage/sets/Commander2021Edition.java b/Mage.Sets/src/mage/sets/Commander2021Edition.java index 1f9dafb57eb..2537a18f9d1 100644 --- a/Mage.Sets/src/mage/sets/Commander2021Edition.java +++ b/Mage.Sets/src/mage/sets/Commander2021Edition.java @@ -24,6 +24,7 @@ public final class Commander2021Edition extends ExpansionSet { cards.add(new SetCardInfo("Ancient Den", 276, Rarity.COMMON, mage.cards.a.AncientDen.class)); cards.add(new SetCardInfo("Angel of the Ruins", 11, Rarity.RARE, mage.cards.a.AngelOfTheRuins.class)); cards.add(new SetCardInfo("Arcane Signet", 234, Rarity.COMMON, mage.cards.a.ArcaneSignet.class)); + cards.add(new SetCardInfo("Archaeomancer's Map", 12, Rarity.RARE, mage.cards.a.ArchaeomancersMap.class)); cards.add(new SetCardInfo("Audacious Reshapers", 47, Rarity.RARE, mage.cards.a.AudaciousReshapers.class)); cards.add(new SetCardInfo("Boros Charm", 210, Rarity.UNCOMMON, mage.cards.b.BorosCharm.class)); cards.add(new SetCardInfo("Boros Locket", 236, Rarity.COMMON, mage.cards.b.BorosLocket.class)); diff --git a/Mage/src/main/java/mage/abilities/common/EntersBattlefieldAllTriggeredAbility.java b/Mage/src/main/java/mage/abilities/common/EntersBattlefieldAllTriggeredAbility.java index df37c43e816..9899a4b9375 100644 --- a/Mage/src/main/java/mage/abilities/common/EntersBattlefieldAllTriggeredAbility.java +++ b/Mage/src/main/java/mage/abilities/common/EntersBattlefieldAllTriggeredAbility.java @@ -88,6 +88,7 @@ public class EntersBattlefieldAllTriggeredAbility extends TriggeredAbilityImpl { return false; } this.getEffects().setValue("permanentEnteringBattlefield", permanent); + this.getEffects().setValue("permanentEnteringControllerId", permanent.getControllerId()); if (setTargetPointer == SetTargetPointer.NONE) { return true; }