mirror of
https://github.com/correl/mage.git
synced 2024-12-26 03:00:11 +00:00
combined "one more more counters added" triggers into a single class
This commit is contained in:
parent
563028043c
commit
0608d2cf3d
3 changed files with 67 additions and 89 deletions
|
@ -1,7 +1,8 @@
|
||||||
package mage.cards.b;
|
package mage.cards.b;
|
||||||
|
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.TriggeredAbilityImpl;
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.common.OneOrMoreCountersAddedTriggeredAbility;
|
||||||
import mage.abilities.effects.common.DrawCardSourceControllerEffect;
|
import mage.abilities.effects.common.DrawCardSourceControllerEffect;
|
||||||
import mage.abilities.effects.common.discard.DiscardControllerEffect;
|
import mage.abilities.effects.common.discard.DiscardControllerEffect;
|
||||||
import mage.abilities.keyword.AdaptAbility;
|
import mage.abilities.keyword.AdaptAbility;
|
||||||
|
@ -9,10 +10,6 @@ import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.SubType;
|
import mage.constants.SubType;
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.counters.CounterType;
|
|
||||||
import mage.game.Game;
|
|
||||||
import mage.game.events.GameEvent;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -34,7 +31,9 @@ public final class BenthicBiomancer extends CardImpl {
|
||||||
this.addAbility(new AdaptAbility(1, "{1}{U}"));
|
this.addAbility(new AdaptAbility(1, "{1}{U}"));
|
||||||
|
|
||||||
// Whenever one or more +1/+1 counters are put on Benthic Biomancer, draw a card, then discard a card.
|
// Whenever one or more +1/+1 counters are put on Benthic Biomancer, draw a card, then discard a card.
|
||||||
this.addAbility(new GrowthChamberGuardianTriggeredAbility());
|
Ability ability = new OneOrMoreCountersAddedTriggeredAbility(new DrawCardSourceControllerEffect(1));
|
||||||
|
ability.addEffect(new DiscardControllerEffect(1).setText(", then discard a card"));
|
||||||
|
this.addAbility(ability);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BenthicBiomancer(final BenthicBiomancer card) {
|
private BenthicBiomancer(final BenthicBiomancer card) {
|
||||||
|
@ -46,38 +45,3 @@ public final class BenthicBiomancer extends CardImpl {
|
||||||
return new BenthicBiomancer(this);
|
return new BenthicBiomancer(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class GrowthChamberGuardianTriggeredAbility extends TriggeredAbilityImpl {
|
|
||||||
|
|
||||||
GrowthChamberGuardianTriggeredAbility() {
|
|
||||||
super(Zone.BATTLEFIELD, new DrawCardSourceControllerEffect(1), true);
|
|
||||||
this.addEffect(new DiscardControllerEffect(1));
|
|
||||||
}
|
|
||||||
|
|
||||||
private GrowthChamberGuardianTriggeredAbility(final GrowthChamberGuardianTriggeredAbility ability) {
|
|
||||||
super(ability);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public GrowthChamberGuardianTriggeredAbility copy() {
|
|
||||||
return new GrowthChamberGuardianTriggeredAbility(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean checkEventType(GameEvent event, Game game) {
|
|
||||||
return event.getType() == GameEvent.EventType.COUNTERS_ADDED;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean checkTrigger(GameEvent event, Game game) {
|
|
||||||
return event.getData().equals(CounterType.P1P1.getName())
|
|
||||||
&& event.getAmount() > 0
|
|
||||||
&& event.getTargetId().equals(this.getSourceId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getRule() {
|
|
||||||
return "Whenever one or more +1/+1 counters are put on {this}, " +
|
|
||||||
"draw a card, then discard a card.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,19 +1,15 @@
|
||||||
package mage.cards.g;
|
package mage.cards.g;
|
||||||
|
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.TriggeredAbilityImpl;
|
import mage.abilities.common.OneOrMoreCountersAddedTriggeredAbility;
|
||||||
import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect;
|
import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect;
|
||||||
import mage.abilities.keyword.AdaptAbility;
|
import mage.abilities.keyword.AdaptAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.SubType;
|
import mage.constants.SubType;
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.counters.CounterType;
|
|
||||||
import mage.filter.FilterCard;
|
import mage.filter.FilterCard;
|
||||||
import mage.filter.predicate.mageobject.NamePredicate;
|
import mage.filter.predicate.mageobject.NamePredicate;
|
||||||
import mage.game.Game;
|
|
||||||
import mage.game.events.GameEvent;
|
|
||||||
import mage.target.common.TargetCardInLibrary;
|
import mage.target.common.TargetCardInLibrary;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
@ -23,6 +19,13 @@ import java.util.UUID;
|
||||||
*/
|
*/
|
||||||
public final class GrowthChamberGuardian extends CardImpl {
|
public final class GrowthChamberGuardian extends CardImpl {
|
||||||
|
|
||||||
|
private static final FilterCard filter
|
||||||
|
= new FilterCard("a card named Growth-Chamber Guardian");
|
||||||
|
|
||||||
|
static {
|
||||||
|
filter.add(new NamePredicate("Growth-Chamber Guardian"));
|
||||||
|
}
|
||||||
|
|
||||||
public GrowthChamberGuardian(UUID ownerId, CardSetInfo setInfo) {
|
public GrowthChamberGuardian(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{G}");
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{G}");
|
||||||
|
|
||||||
|
@ -36,7 +39,7 @@ public final class GrowthChamberGuardian extends CardImpl {
|
||||||
this.addAbility(new AdaptAbility(2, "{2}{G}"));
|
this.addAbility(new AdaptAbility(2, "{2}{G}"));
|
||||||
|
|
||||||
// Whenever one or more +1/+1 counters are put on Growth-Chamber Guardian, you may search your library for a card named Growth-Chamber Guardian, reveal it, put it into your hand, then shuffle your library.
|
// Whenever one or more +1/+1 counters are put on Growth-Chamber Guardian, you may search your library for a card named Growth-Chamber Guardian, reveal it, put it into your hand, then shuffle your library.
|
||||||
this.addAbility(new GrowthChamberGuardianTriggeredAbility());
|
this.addAbility(new OneOrMoreCountersAddedTriggeredAbility(new SearchLibraryPutInHandEffect(new TargetCardInLibrary(filter), true), true));
|
||||||
}
|
}
|
||||||
|
|
||||||
private GrowthChamberGuardian(final GrowthChamberGuardian card) {
|
private GrowthChamberGuardian(final GrowthChamberGuardian card) {
|
||||||
|
@ -48,45 +51,3 @@ public final class GrowthChamberGuardian extends CardImpl {
|
||||||
return new GrowthChamberGuardian(this);
|
return new GrowthChamberGuardian(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class GrowthChamberGuardianTriggeredAbility extends TriggeredAbilityImpl {
|
|
||||||
|
|
||||||
private static final FilterCard filter
|
|
||||||
= new FilterCard("a card named Growth-Chamber Guardian");
|
|
||||||
|
|
||||||
static {
|
|
||||||
filter.add(new NamePredicate("Growth-Chamber Guardian"));
|
|
||||||
}
|
|
||||||
|
|
||||||
GrowthChamberGuardianTriggeredAbility() {
|
|
||||||
super(Zone.BATTLEFIELD, new SearchLibraryPutInHandEffect(new TargetCardInLibrary(filter), true), true);
|
|
||||||
}
|
|
||||||
|
|
||||||
private GrowthChamberGuardianTriggeredAbility(final GrowthChamberGuardianTriggeredAbility ability) {
|
|
||||||
super(ability);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public GrowthChamberGuardianTriggeredAbility copy() {
|
|
||||||
return new GrowthChamberGuardianTriggeredAbility(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean checkEventType(GameEvent event, Game game) {
|
|
||||||
return event.getType() == GameEvent.EventType.COUNTERS_ADDED;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean checkTrigger(GameEvent event, Game game) {
|
|
||||||
return event.getData().equals(CounterType.P1P1.getName())
|
|
||||||
&& event.getAmount() > 0
|
|
||||||
&& event.getTargetId().equals(this.getSourceId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getRule() {
|
|
||||||
return "Whenever one or more +1/+1 counters are put on {this}, " +
|
|
||||||
"you may search your library for a card named Growth-Chamber Guardian, " +
|
|
||||||
"reveal it, put it into your hand, then shuffle your library.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,53 @@
|
||||||
|
package mage.abilities.common;
|
||||||
|
|
||||||
|
import mage.abilities.TriggeredAbilityImpl;
|
||||||
|
import mage.abilities.effects.Effect;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import mage.counters.CounterType;
|
||||||
|
import mage.game.Game;
|
||||||
|
import mage.game.events.GameEvent;
|
||||||
|
|
||||||
|
public class OneOrMoreCountersAddedTriggeredAbility extends TriggeredAbilityImpl {
|
||||||
|
|
||||||
|
private final CounterType counterType;
|
||||||
|
|
||||||
|
public OneOrMoreCountersAddedTriggeredAbility(Effect effect) {
|
||||||
|
this(effect, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public OneOrMoreCountersAddedTriggeredAbility(Effect effect, boolean optional) {
|
||||||
|
this(effect, optional, CounterType.P1P1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public OneOrMoreCountersAddedTriggeredAbility(Effect effect, boolean optional, CounterType counterType) {
|
||||||
|
super(Zone.BATTLEFIELD, effect, true);
|
||||||
|
this.counterType = counterType;
|
||||||
|
}
|
||||||
|
|
||||||
|
private OneOrMoreCountersAddedTriggeredAbility(final OneOrMoreCountersAddedTriggeredAbility ability) {
|
||||||
|
super(ability);
|
||||||
|
this.counterType = ability.counterType;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public OneOrMoreCountersAddedTriggeredAbility copy() {
|
||||||
|
return new OneOrMoreCountersAddedTriggeredAbility(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean checkEventType(GameEvent event, Game game) {
|
||||||
|
return event.getType() == GameEvent.EventType.COUNTERS_ADDED;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean checkTrigger(GameEvent event, Game game) {
|
||||||
|
return event.getData().equals(counterType.getName())
|
||||||
|
&& event.getAmount() > 0
|
||||||
|
&& event.getTargetId().equals(this.getSourceId());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getRule() {
|
||||||
|
return "Whenever one or more " + counterType + " counters are put on {this}, " + super.getRule();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue