mirror of
https://github.com/correl/mage.git
synced 2025-01-12 11:08:01 +00:00
Updated some targets and filters
This commit is contained in:
parent
56777cb0d0
commit
4e3961a819
10 changed files with 28 additions and 33 deletions
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
package mage.cards.e;
|
package mage.cards.e;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
@ -23,7 +22,7 @@ import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
*/
|
*/
|
||||||
public final class EnergyTap extends CardImpl {
|
public final class EnergyTap extends CardImpl {
|
||||||
|
|
||||||
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("untapped creature you crontrol");
|
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("untapped creature you control");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.add(Predicates.not(new TappedPredicate()));
|
filter.add(Predicates.not(new TappedPredicate()));
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
package mage.cards.r;
|
package mage.cards.r;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.ActivateAsSorceryActivatedAbility;
|
import mage.abilities.common.ActivateAsSorceryActivatedAbility;
|
||||||
import mage.abilities.costs.common.ReturnToHandFromBattlefieldSourceCost;
|
import mage.abilities.costs.common.ReturnToHandFromBattlefieldSourceCost;
|
||||||
|
@ -10,28 +10,26 @@ import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.StaticFilters;
|
||||||
import mage.filter.common.FilterCreatureCard;
|
|
||||||
import mage.target.common.TargetCardInYourGraveyard;
|
import mage.target.common.TargetCardInYourGraveyard;
|
||||||
import mage.target.common.TargetControlledPermanent;
|
import mage.target.common.TargetControlledPermanent;
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author jeffwadsworth
|
* @author jeffwadsworth
|
||||||
*/
|
*/
|
||||||
public final class RecurringNightmare extends CardImpl {
|
public final class RecurringNightmare extends CardImpl {
|
||||||
|
|
||||||
private static final FilterCreatureCard filter = new FilterCreatureCard("creature card");
|
|
||||||
private static final FilterControlledCreaturePermanent filter2 = new FilterControlledCreaturePermanent("creature");
|
|
||||||
|
|
||||||
public RecurringNightmare(UUID ownerId, CardSetInfo setInfo) {
|
public RecurringNightmare(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{2}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{B}");
|
||||||
|
|
||||||
// Sacrifice a creature, Return Recurring Nightmare to its owner's hand: Return target creature card from your graveyard to the battlefield. Activate this ability only any time you could cast a sorcery.
|
// Sacrifice a creature, Return Recurring Nightmare to its owner's hand: Return target creature card from your graveyard to the battlefield. Activate this ability only any time you could cast a sorcery.
|
||||||
Ability ability = new ActivateAsSorceryActivatedAbility(Zone.BATTLEFIELD, new ReturnFromGraveyardToBattlefieldTargetEffect(), new SacrificeTargetCost(new TargetControlledPermanent(filter2)));
|
Ability ability = new ActivateAsSorceryActivatedAbility(
|
||||||
ability.addTarget(new TargetCardInYourGraveyard(filter));
|
Zone.BATTLEFIELD,
|
||||||
|
new ReturnFromGraveyardToBattlefieldTargetEffect(),
|
||||||
|
new SacrificeTargetCost(new TargetControlledPermanent(StaticFilters.FILTER_CONTROLLED_CREATURE))
|
||||||
|
);
|
||||||
|
ability.addTarget(new TargetCardInYourGraveyard(StaticFilters.FILTER_CARD_CREATURE));
|
||||||
ability.addCost(new ReturnToHandFromBattlefieldSourceCost());
|
ability.addCost(new ReturnToHandFromBattlefieldSourceCost());
|
||||||
this.addAbility(ability);
|
this.addAbility(ability);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
package mage.cards.s;
|
package mage.cards.s;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
@ -17,7 +16,7 @@ import mage.constants.CardType;
|
||||||
import mage.constants.SubType;
|
import mage.constants.SubType;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.counters.CounterType;
|
import mage.counters.CounterType;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.StaticFilters;
|
||||||
import mage.target.common.TargetControlledCreaturePermanent;
|
import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -44,7 +43,7 @@ public final class SpikeRogue extends CardImpl {
|
||||||
|
|
||||||
// {2}, Remove a +1/+1 counter from a creature you control: Put a +1/+1 counter on Spike Rogue.
|
// {2}, Remove a +1/+1 counter from a creature you control: Put a +1/+1 counter on Spike Rogue.
|
||||||
Ability ability2 = new SimpleActivatedAbility(Zone.BATTLEFIELD, new AddCountersSourceEffect(CounterType.P1P1.createInstance(1)), new GenericManaCost(2));
|
Ability ability2 = new SimpleActivatedAbility(Zone.BATTLEFIELD, new AddCountersSourceEffect(CounterType.P1P1.createInstance(1)), new GenericManaCost(2));
|
||||||
ability2.addCost(new RemoveCounterCost(new TargetControlledCreaturePermanent(1, 1, new FilterControlledCreaturePermanent(), true), CounterType.P1P1));
|
ability2.addCost(new RemoveCounterCost(new TargetControlledCreaturePermanent(1, 1, StaticFilters.FILTER_CONTROLLED_CREATURE, true), CounterType.P1P1));
|
||||||
this.addAbility(ability2);
|
this.addAbility(ability2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public class FilterCard extends FilterObject<Card> {
|
||||||
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(card, sourceId, playerId), game);
|
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(card, sourceId, playerId), game);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void add(ObjectPlayerPredicate predicate) {
|
public final void add(ObjectPlayerPredicate predicate) {
|
||||||
if (isLockedFilter()) {
|
if (isLockedFilter()) {
|
||||||
throw new UnsupportedOperationException("You may not modify a locked filter");
|
throw new UnsupportedOperationException("You may not modify a locked filter");
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@ public abstract class FilterImpl<E> implements Filter<E> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setMessage(String message) {
|
public final void setMessage(String message) {
|
||||||
if (isLockedFilter()) {
|
if (isLockedFilter()) {
|
||||||
throw new UnsupportedOperationException("You may not modify a locked filter");
|
throw new UnsupportedOperationException("You may not modify a locked filter");
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,7 @@ public class FilterPermanent extends FilterObject<Permanent> implements FilterIn
|
||||||
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(permanent, sourceId, playerId), game);
|
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(permanent, sourceId, playerId), game);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void add(ObjectPlayerPredicate predicate) {
|
public final void add(ObjectPlayerPredicate predicate) {
|
||||||
if (isLockedFilter()) {
|
if (isLockedFilter()) {
|
||||||
throw new UnsupportedOperationException("You may not modify a locked filter");
|
throw new UnsupportedOperationException("You may not modify a locked filter");
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ public class FilterStackObject extends FilterObject<StackObject> {
|
||||||
protected List<ObjectPlayerPredicate<ObjectPlayer<Permanent>>> extraPredicates = new ArrayList<>();
|
protected List<ObjectPlayerPredicate<ObjectPlayer<Permanent>>> extraPredicates = new ArrayList<>();
|
||||||
|
|
||||||
public FilterStackObject() {
|
public FilterStackObject() {
|
||||||
super("spell or ability");
|
this("spell or ability");
|
||||||
}
|
}
|
||||||
|
|
||||||
public FilterStackObject(String name) {
|
public FilterStackObject(String name) {
|
||||||
|
@ -40,7 +40,7 @@ public class FilterStackObject extends FilterObject<StackObject> {
|
||||||
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(stackObject, sourceId, playerId), game);
|
return Predicates.and(extraPredicates).apply(new ObjectSourcePlayer(stackObject, sourceId, playerId), game);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void add(ObjectPlayerPredicate predicate) {
|
public final void add(ObjectPlayerPredicate predicate) {
|
||||||
if (isLockedFilter()) {
|
if (isLockedFilter()) {
|
||||||
throw new UnsupportedOperationException("You may not modify a locked filter");
|
throw new UnsupportedOperationException("You may not modify a locked filter");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
package mage.target;
|
package mage.target;
|
||||||
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -8,6 +7,7 @@ import mage.MageObject;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.filter.FilterPermanent;
|
import mage.filter.FilterPermanent;
|
||||||
|
import mage.filter.StaticFilters;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
|
|
||||||
|
@ -20,11 +20,11 @@ public class TargetPermanent extends TargetObject {
|
||||||
protected FilterPermanent filter;
|
protected FilterPermanent filter;
|
||||||
|
|
||||||
public TargetPermanent() {
|
public TargetPermanent() {
|
||||||
this(1, 1, new FilterPermanent(), false);
|
this(StaticFilters.FILTER_PERMANENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetPermanent(FilterPermanent filter) {
|
public TargetPermanent(FilterPermanent filter) {
|
||||||
this(1, 1, filter, false);
|
this(1, filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetPermanent(int numTargets, FilterPermanent filter) {
|
public TargetPermanent(int numTargets, FilterPermanent filter) {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
package mage.target.common;
|
package mage.target.common;
|
||||||
|
|
||||||
|
import mage.filter.StaticFilters;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -10,19 +10,19 @@ import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
public class TargetControlledCreaturePermanent extends TargetControlledPermanent {
|
public class TargetControlledCreaturePermanent extends TargetControlledPermanent {
|
||||||
|
|
||||||
public TargetControlledCreaturePermanent() {
|
public TargetControlledCreaturePermanent() {
|
||||||
this(1, 1, new FilterControlledCreaturePermanent(), false);
|
this(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledCreaturePermanent(int numTargets) {
|
public TargetControlledCreaturePermanent(int numTargets) {
|
||||||
this(numTargets, numTargets, new FilterControlledCreaturePermanent(), false);
|
this(numTargets, numTargets);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledCreaturePermanent(int minNumTargets, int maxNumTargets) {
|
public TargetControlledCreaturePermanent(int minNumTargets, int maxNumTargets) {
|
||||||
this(minNumTargets, maxNumTargets, new FilterControlledCreaturePermanent(), false);
|
this(minNumTargets, maxNumTargets, StaticFilters.FILTER_CONTROLLED_CREATURE, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledCreaturePermanent(FilterControlledCreaturePermanent filter) {
|
public TargetControlledCreaturePermanent(FilterControlledCreaturePermanent filter) {
|
||||||
super(1, 1, filter, false);
|
this(1, 1, filter, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledCreaturePermanent(int minNumTargets, int maxNumTargets, FilterControlledCreaturePermanent filter, boolean notTarget) {
|
public TargetControlledCreaturePermanent(int minNumTargets, int maxNumTargets, FilterControlledCreaturePermanent filter, boolean notTarget) {
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
|
|
||||||
|
|
||||||
package mage.target.common;
|
package mage.target.common;
|
||||||
|
|
||||||
|
import mage.filter.StaticFilters;
|
||||||
import mage.filter.common.FilterControlledPermanent;
|
import mage.filter.common.FilterControlledPermanent;
|
||||||
import mage.target.TargetPermanent;
|
import mage.target.TargetPermanent;
|
||||||
|
|
||||||
|
@ -12,11 +11,11 @@ import mage.target.TargetPermanent;
|
||||||
public class TargetControlledPermanent extends TargetPermanent {
|
public class TargetControlledPermanent extends TargetPermanent {
|
||||||
|
|
||||||
public TargetControlledPermanent() {
|
public TargetControlledPermanent() {
|
||||||
this(1, 1, new FilterControlledPermanent(), false);
|
this(1, 1, StaticFilters.FILTER_CONTROLLED_PERMANENT, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledPermanent(int numTargets) {
|
public TargetControlledPermanent(int numTargets) {
|
||||||
this(numTargets, numTargets, new FilterControlledPermanent(), false);
|
this(numTargets, numTargets, StaticFilters.FILTER_CONTROLLED_PERMANENT, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetControlledPermanent(FilterControlledPermanent filter) {
|
public TargetControlledPermanent(FilterControlledPermanent filter) {
|
||||||
|
|
Loading…
Reference in a new issue