diff --git a/Mage.Sets/src/mage/cards/a/AbandonedCampground.java b/Mage.Sets/src/mage/cards/a/AbandonedCampground.java new file mode 100644 index 00000000000..ee16f37be92 --- /dev/null +++ b/Mage.Sets/src/mage/cards/a/AbandonedCampground.java @@ -0,0 +1,37 @@ +package mage.cards.a; + +import mage.abilities.common.EntersBattlefieldTappedUnlessAbility; +import mage.abilities.condition.common.APlayerHas13LifeCondition; +import mage.abilities.mana.BlueManaAbility; +import mage.abilities.mana.WhiteManaAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class AbandonedCampground extends CardImpl { + + public AbandonedCampground(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.LAND}, ""); + + // Abandoned Campground enters tapped unless a player has 13 or less life. + this.addAbility(new EntersBattlefieldTappedUnlessAbility(APlayerHas13LifeCondition.instance)); + + // {T}: Add {W} or {U}. + this.addAbility(new WhiteManaAbility()); + this.addAbility(new BlueManaAbility()); + } + + private AbandonedCampground(final AbandonedCampground card) { + super(card); + } + + @Override + public AbandonedCampground copy() { + return new AbandonedCampground(this); + } +} diff --git a/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java b/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java index 8e6ed5457b0..8d0dbe0127f 100644 --- a/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java +++ b/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java @@ -21,6 +21,7 @@ public final class DuskmournHouseOfHorror extends ExpansionSet { this.hasBasicLands = true; this.hasBoosters = false; // temporary + cards.add(new SetCardInfo("Abandoned Campground", 255, Rarity.COMMON, mage.cards.a.AbandonedCampground.class)); cards.add(new SetCardInfo("Chainsaw", 128, Rarity.RARE, mage.cards.c.Chainsaw.class)); cards.add(new SetCardInfo("Cursed Recording", 131, Rarity.RARE, mage.cards.c.CursedRecording.class)); cards.add(new SetCardInfo("Demonic Counsel", 92, Rarity.RARE, mage.cards.d.DemonicCounsel.class)); diff --git a/Mage/src/main/java/mage/abilities/condition/common/APlayerHas13LifeCondition.java b/Mage/src/main/java/mage/abilities/condition/common/APlayerHas13LifeCondition.java new file mode 100644 index 00000000000..9d2a6018541 --- /dev/null +++ b/Mage/src/main/java/mage/abilities/condition/common/APlayerHas13LifeCondition.java @@ -0,0 +1,32 @@ +package mage.abilities.condition.common; + +import mage.abilities.Ability; +import mage.abilities.condition.Condition; +import mage.game.Game; +import mage.players.Player; + +import java.util.Objects; + +/** + * @author TheElk801 + */ +public enum APlayerHas13LifeCondition implements Condition { + instance; + + @Override + public boolean apply(Game game, Ability source) { + return game + .getState() + .getPlayersInRange(source.getControllerId(), game) + .stream() + .map(game::getPlayer) + .filter(Objects::nonNull) + .mapToInt(Player::getLife) + .anyMatch(x -> x <= 13); + } + + @Override + public String toString() { + return "a player has 13 or less life"; + } +}