mirror of
https://github.com/correl/mage.git
synced 2024-12-26 03:00:11 +00:00
Implemented Alpine Houndmaster
This commit is contained in:
parent
2d2b39aaa3
commit
3a3f04d233
2 changed files with 141 additions and 0 deletions
140
Mage.Sets/src/mage/cards/a/AlpineHoundmaster.java
Normal file
140
Mage.Sets/src/mage/cards/a/AlpineHoundmaster.java
Normal file
|
@ -0,0 +1,140 @@
|
||||||
|
package mage.cards.a;
|
||||||
|
|
||||||
|
import mage.MageInt;
|
||||||
|
import mage.MageObject;
|
||||||
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.common.AttacksTriggeredAbility;
|
||||||
|
import mage.abilities.common.EntersBattlefieldTriggeredAbility;
|
||||||
|
import mage.abilities.dynamicvalue.DynamicValue;
|
||||||
|
import mage.abilities.dynamicvalue.common.PermanentsOnBattlefieldCount;
|
||||||
|
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||||
|
import mage.abilities.effects.OneShotEffect;
|
||||||
|
import mage.abilities.effects.common.continuous.BoostSourceEffect;
|
||||||
|
import mage.cards.*;
|
||||||
|
import mage.constants.*;
|
||||||
|
import mage.filter.FilterCard;
|
||||||
|
import mage.filter.FilterPermanent;
|
||||||
|
import mage.filter.common.FilterAttackingCreature;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.NamePredicate;
|
||||||
|
import mage.filter.predicate.permanent.AnotherPredicate;
|
||||||
|
import mage.game.Game;
|
||||||
|
import mage.players.Player;
|
||||||
|
import mage.target.common.TargetCardInLibrary;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author TheElk801
|
||||||
|
*/
|
||||||
|
public final class AlpineHoundmaster extends CardImpl {
|
||||||
|
|
||||||
|
private static final FilterPermanent filter = new FilterAttackingCreature();
|
||||||
|
|
||||||
|
static {
|
||||||
|
filter.add(AnotherPredicate.instance);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final DynamicValue xValue = new PermanentsOnBattlefieldCount(filter);
|
||||||
|
|
||||||
|
public AlpineHoundmaster(UUID ownerId, CardSetInfo setInfo) {
|
||||||
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{R}{W}");
|
||||||
|
|
||||||
|
this.subtype.add(SubType.HUMAN);
|
||||||
|
this.subtype.add(SubType.WARRIOR);
|
||||||
|
this.power = new MageInt(2);
|
||||||
|
this.toughness = new MageInt(2);
|
||||||
|
|
||||||
|
// When Alpine Houndmaster enters the battlefield, you may search your library for a card named Alpine Watchdog and/or a card named Igneous Cur, reveal them, put them into your hand, then shuffle your library.
|
||||||
|
this.addAbility(new EntersBattlefieldTriggeredAbility(new AlpineHoundmasterEffect(), true));
|
||||||
|
|
||||||
|
// Whenever Alpine Houndmaster attacks, it gets +X/+0 until end of turn, where X is the number of other attacking creatures.
|
||||||
|
this.addAbility(new AttacksTriggeredAbility(new BoostSourceEffect(
|
||||||
|
xValue, StaticValue.get(0), Duration.EndOfTurn
|
||||||
|
), false, "it gets +X/+0 until end of turn, where X is the number of other attacking creatures"));
|
||||||
|
}
|
||||||
|
|
||||||
|
private AlpineHoundmaster(final AlpineHoundmaster card) {
|
||||||
|
super(card);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AlpineHoundmaster copy() {
|
||||||
|
return new AlpineHoundmaster(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AlpineHoundmasterEffect extends OneShotEffect {
|
||||||
|
|
||||||
|
AlpineHoundmasterEffect() {
|
||||||
|
super(Outcome.Benefit);
|
||||||
|
staticText = "search your library for a card named Alpine Watchdog and/or a card named Igneous Cur, " +
|
||||||
|
"reveal them, put them into your hand, then shuffle your library";
|
||||||
|
}
|
||||||
|
|
||||||
|
private AlpineHoundmasterEffect(final AlpineHoundmasterEffect effect) {
|
||||||
|
super(effect);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AlpineHoundmasterEffect copy() {
|
||||||
|
return new AlpineHoundmasterEffect(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
|
Player player = game.getPlayer(source.getControllerId());
|
||||||
|
if (player == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
TargetCardInLibrary target = new AlpineHoundmasterTarget();
|
||||||
|
player.searchLibrary(target, source, game);
|
||||||
|
Cards cards = new CardsImpl(target.getTargets());
|
||||||
|
player.revealCards(source, cards, game);
|
||||||
|
player.moveCards(cards, Zone.HAND, source, game);
|
||||||
|
player.shuffleLibrary(source, game);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AlpineHoundmasterTarget extends TargetCardInLibrary {
|
||||||
|
|
||||||
|
private static final FilterCard filter
|
||||||
|
= new FilterCard("card named Alpine Watchdog and/or a card named Igneous Cur");
|
||||||
|
|
||||||
|
static {
|
||||||
|
filter.add(Predicates.or(
|
||||||
|
new NamePredicate("Alpine Watchdog"),
|
||||||
|
new NamePredicate("Igneous Cur")
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
AlpineHoundmasterTarget() {
|
||||||
|
super(0, 2, filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
private AlpineHoundmasterTarget(final AlpineHoundmasterTarget target) {
|
||||||
|
super(target);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AlpineHoundmasterTarget copy() {
|
||||||
|
return new AlpineHoundmasterTarget(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canTarget(UUID controllerId, UUID id, Ability source, Game game) {
|
||||||
|
if (!super.canTarget(controllerId, id, source, game)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Card card = game.getCard(id);
|
||||||
|
if (card == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return this.getTargets()
|
||||||
|
.stream()
|
||||||
|
.map(game::getCard)
|
||||||
|
.map(MageObject::getName)
|
||||||
|
.noneMatch(card.getName()::equals);
|
||||||
|
}
|
||||||
|
}
|
|
@ -34,6 +34,7 @@ public final class CoreSet2021 extends ExpansionSet {
|
||||||
this.maxCardNumberInBooster = 274;
|
this.maxCardNumberInBooster = 274;
|
||||||
|
|
||||||
cards.add(new SetCardInfo("Adherent of Hope", 321, Rarity.COMMON, mage.cards.a.AdherentOfHope.class));
|
cards.add(new SetCardInfo("Adherent of Hope", 321, Rarity.COMMON, mage.cards.a.AdherentOfHope.class));
|
||||||
|
cards.add(new SetCardInfo("Alpine Houndmaster", 215, Rarity.UNCOMMON, mage.cards.a.AlpineHoundmaster.class));
|
||||||
cards.add(new SetCardInfo("Angelic Ascension", 3, Rarity.UNCOMMON, mage.cards.a.AngelicAscension.class));
|
cards.add(new SetCardInfo("Angelic Ascension", 3, Rarity.UNCOMMON, mage.cards.a.AngelicAscension.class));
|
||||||
cards.add(new SetCardInfo("Azusa, Lost but Seeking", 173, Rarity.RARE, mage.cards.a.AzusaLostButSeeking.class));
|
cards.add(new SetCardInfo("Azusa, Lost but Seeking", 173, Rarity.RARE, mage.cards.a.AzusaLostButSeeking.class));
|
||||||
cards.add(new SetCardInfo("Bad Deal", 89, Rarity.UNCOMMON, mage.cards.b.BadDeal.class));
|
cards.add(new SetCardInfo("Bad Deal", 89, Rarity.UNCOMMON, mage.cards.b.BadDeal.class));
|
||||||
|
|
Loading…
Reference in a new issue