mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
[filters] Replaced abilities condition with Predicate
This commit is contained in:
parent
c59087e827
commit
0d2053c634
46 changed files with 113 additions and 105 deletions
|
@ -42,6 +42,8 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Loki
|
* @author Loki
|
||||||
|
@ -51,8 +53,7 @@ public class BloodfireDwarf extends CardImpl<BloodfireDwarf> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public BloodfireDwarf(UUID ownerId) {
|
public BloodfireDwarf(UUID ownerId) {
|
||||||
|
|
|
@ -37,6 +37,7 @@ import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
@ -50,7 +51,7 @@ public class EatenBySpiders extends CardImpl<EatenBySpiders> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public EatenBySpiders(UUID ownerId) {
|
public EatenBySpiders(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.continious.BoostControlledEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -47,7 +48,7 @@ public class FavorableWinds extends CardImpl<FavorableWinds> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Creatures you control with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Creatures you control with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public FavorableWinds(UUID ownerId) {
|
public FavorableWinds(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.TargetPlayer;
|
import mage.target.TargetPlayer;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -47,7 +48,7 @@ public class Thunderbolt extends CardImpl<Thunderbolt> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public Thunderbolt(UUID ownerId) {
|
public Thunderbolt(UUID ownerId) {
|
||||||
|
|
|
@ -33,7 +33,6 @@ import java.util.UUID;
|
||||||
import mage.Constants.CardType;
|
import mage.Constants.CardType;
|
||||||
import mage.Constants.Rarity;
|
import mage.Constants.Rarity;
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.Ability;
|
|
||||||
import mage.abilities.common.SpellCastTriggeredAbility;
|
import mage.abilities.common.SpellCastTriggeredAbility;
|
||||||
import mage.abilities.dynamicvalue.common.StaticValue;
|
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||||
import mage.abilities.effects.common.DamageAllEffect;
|
import mage.abilities.effects.common.DamageAllEffect;
|
||||||
|
@ -41,6 +40,8 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.filter.common.FilterSpiritOrArcaneCard;
|
import mage.filter.common.FilterSpiritOrArcaneCard;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Loki
|
* @author Loki
|
||||||
|
@ -51,8 +52,7 @@ public class Earthshaker extends CardImpl<Earthshaker> {
|
||||||
private final static FilterCreaturePermanent creatureFilter = new FilterCreaturePermanent("creature without flying");
|
private final static FilterCreaturePermanent creatureFilter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
creatureFilter.getAbilities().add((Ability) FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
creatureFilter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Earthshaker(UUID ownerId) {
|
public Earthshaker(UUID ownerId) {
|
||||||
|
|
|
@ -36,6 +36,7 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Loki
|
* @author Loki
|
||||||
|
@ -45,7 +46,7 @@ public class GaleForce extends CardImpl<GaleForce> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public GaleForce(UUID ownerId) {
|
public GaleForce(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,8 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -46,8 +48,7 @@ public class RyuseiTheFallingStar extends CardImpl<RyuseiTheFallingStar> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public RyuseiTheFallingStar(UUID ownerID) {
|
public RyuseiTheFallingStar(UUID ownerID) {
|
||||||
|
|
|
@ -38,6 +38,7 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -48,7 +49,7 @@ public class ScattershotArcher extends CardImpl<ScattershotArcher> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public ScattershotArcher(UUID ownerId) {
|
public ScattershotArcher(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.DestroyTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetArtifactPermanent;
|
import mage.target.common.TargetArtifactPermanent;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -47,7 +48,7 @@ public class CrushingVines extends CardImpl<CrushingVines> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public CrushingVines(UUID ownerId) {
|
public CrushingVines(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,8 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.FilterSpell;
|
import mage.filter.FilterSpell;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -55,8 +57,7 @@ public class TiborAndLumia extends CardImpl<TiborAndLumia> {
|
||||||
static {
|
static {
|
||||||
filterBlue.setUseColor(true);
|
filterBlue.setUseColor(true);
|
||||||
filterBlue.getColor().setBlue(true);
|
filterBlue.getColor().setBlue(true);
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
filterRed.setUseColor(true);
|
filterRed.setUseColor(true);
|
||||||
filterRed.getColor().setRed(true);
|
filterRed.getColor().setRed(true);
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,6 +46,7 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.keyword.TransformAbility;
|
import mage.abilities.keyword.TransformAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -57,7 +58,7 @@ public class DaybreakRanger extends CardImpl<DaybreakRanger> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public DaybreakRanger(UUID ownerId) {
|
public DaybreakRanger(UUID ownerId) {
|
||||||
|
|
|
@ -37,6 +37,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -48,7 +49,7 @@ public class GeistcatchersRig extends CardImpl<GeistcatchersRig> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public GeistcatchersRig(UUID ownerId) {
|
public GeistcatchersRig(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.keyword.DefenderAbility;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -50,7 +51,7 @@ public class OneEyedScarecrow extends CardImpl<OneEyedScarecrow> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Creatures with flying your opponents control");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Creatures with flying your opponents control");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
filter.setTargetController(TargetController.OPPONENT);
|
filter.setTargetController(TargetController.OPPONENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,8 @@ import mage.abilities.keyword.FlashbackAbility;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -47,8 +49,7 @@ public class RollingTemblor extends CardImpl<RollingTemblor> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public RollingTemblor(UUID ownerId) {
|
public RollingTemblor(UUID ownerId) {
|
||||||
|
|
|
@ -31,12 +31,11 @@ import java.util.UUID;
|
||||||
import mage.Constants.CardType;
|
import mage.Constants.CardType;
|
||||||
import mage.Constants.Rarity;
|
import mage.Constants.Rarity;
|
||||||
import mage.Constants.TargetController;
|
import mage.Constants.TargetController;
|
||||||
import mage.Constants.TimingRule;
|
|
||||||
import mage.abilities.costs.mana.ManaCostsImpl;
|
|
||||||
import mage.abilities.effects.common.ReturnToHandTargetEffect;
|
import mage.abilities.effects.common.ReturnToHandTargetEffect;
|
||||||
import mage.abilities.keyword.FlashbackAbility;
|
import mage.abilities.keyword.FlashbackAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.FilterCard;
|
import mage.filter.FilterCard;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCardInExile;
|
import mage.target.common.TargetCardInExile;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -49,7 +48,7 @@ public class RunicRepetition extends CardImpl<RunicRepetition> {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.setTargetOwner(TargetController.YOU);
|
filter.setTargetOwner(TargetController.YOU);
|
||||||
filter.getAbilities().add(new FlashbackAbility(new ManaCostsImpl("{0}"), TimingRule.INSTANT));
|
filter.add(new AbilityPredicate(FlashbackAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public RunicRepetition(UUID ownerId) {
|
public RunicRepetition(UUID ownerId) {
|
||||||
|
|
|
@ -34,6 +34,8 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -47,9 +49,8 @@ public class HurlyBurly extends CardImpl<HurlyBurly> {
|
||||||
private final static FilterCreaturePermanent filterWithFlying = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filterWithFlying = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filterWithoutFlying.getAbilities().add(FlyingAbility.getInstance());
|
filterWithoutFlying.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filterWithoutFlying.setNotAbilities(true);
|
filterWithFlying.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
filterWithFlying.getAbilities().add(FlyingAbility.getInstance());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public HurlyBurly(UUID ownerId) {
|
public HurlyBurly(UUID ownerId) {
|
||||||
|
|
|
@ -37,6 +37,8 @@ import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
@ -69,8 +71,7 @@ class EarthquakeEffect extends OneShotEffect<EarthquakeEffect> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent();
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public EarthquakeEffect() {
|
public EarthquakeEffect() {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -45,7 +46,7 @@ public class Windstorm extends CardImpl<Windstorm> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public Windstorm(UUID ownerId) {
|
public Windstorm(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.effects.common.TapTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,7 +52,7 @@ public class AirServant extends CardImpl<AirServant> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public AirServant(UUID ownerId) {
|
public AirServant(UUID ownerId) {
|
||||||
|
|
|
@ -36,6 +36,7 @@ import mage.abilities.effects.common.DestroyTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,7 +48,7 @@ public class Plummet extends CardImpl<Plummet> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public Plummet(UUID ownerId) {
|
public Plummet(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.keyword.ReachAbility;
|
import mage.abilities.keyword.ReachAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -50,7 +51,7 @@ public class StingerflingSpider extends CardImpl<StingerflingSpider> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public StingerflingSpider(UUID ownerId) {
|
public StingerflingSpider(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.keyword.HasteAbility;
|
import mage.abilities.keyword.HasteAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
|
|
||||||
|
@ -52,7 +53,7 @@ public class ThundermawHellkite extends CardImpl<ThundermawHellkite> {
|
||||||
final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creatures with flying your opponents control");
|
final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creatures with flying your opponents control");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
filter.setTargetController(Constants.TargetController.OPPONENT);
|
filter.setTargetController(Constants.TargetController.OPPONENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,6 +41,8 @@ import mage.cards.CardImpl;
|
||||||
import mage.filter.Filter;
|
import mage.filter.Filter;
|
||||||
import mage.filter.common.FilterControlledPermanent;
|
import mage.filter.common.FilterControlledPermanent;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetControlledPermanent;
|
import mage.target.common.TargetControlledPermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,8 +56,7 @@ public class KrarkClanShaman extends CardImpl<KrarkClanShaman> {
|
||||||
static {
|
static {
|
||||||
filterSacrificed.getCardType().add(CardType.ARTIFACT);
|
filterSacrificed.getCardType().add(CardType.ARTIFACT);
|
||||||
filterSacrificed.setScopeCardType(Filter.ComparisonScope.Any);
|
filterSacrificed.setScopeCardType(Filter.ComparisonScope.Any);
|
||||||
filterTargetedCreatures.getAbilities().add(FlyingAbility.getInstance());
|
filterTargetedCreatures.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filterTargetedCreatures.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -33,13 +33,14 @@ import mage.Constants.CardType;
|
||||||
import mage.Constants.Outcome;
|
import mage.Constants.Outcome;
|
||||||
import mage.Constants.Rarity;
|
import mage.Constants.Rarity;
|
||||||
import mage.Constants.Zone;
|
import mage.Constants.Zone;
|
||||||
import mage.cards.CardImpl;
|
|
||||||
import mage.counters.CounterType;
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.effects.common.DestroyTargetEffect;
|
import mage.abilities.effects.common.DestroyTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
|
import mage.cards.CardImpl;
|
||||||
|
import mage.counters.CounterType;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
@ -54,7 +55,7 @@ public class PistusStrike extends CardImpl<PistusStrike> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public PistusStrike(UUID ownerId) {
|
public PistusStrike(UUID ownerId) {
|
||||||
|
|
|
@ -39,6 +39,7 @@ import mage.abilities.keyword.ReachAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.FilterSpell;
|
import mage.filter.FilterSpell;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.filter.predicate.mageobject.SubtypePredicate;
|
import mage.filter.predicate.mageobject.SubtypePredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -53,7 +54,7 @@ public class LysAlanaBowmaster extends CardImpl<LysAlanaBowmaster> {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filterElf.add(new SubtypePredicate("Elf"));
|
filterElf.add(new SubtypePredicate("Elf"));
|
||||||
filterFlying.getAbilities().add(FlyingAbility.getInstance());
|
filterFlying.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public LysAlanaBowmaster(UUID ownerId) {
|
public LysAlanaBowmaster(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -45,7 +46,7 @@ public class CorrosiveGale extends CardImpl<CorrosiveGale> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public CorrosiveGale(UUID ownerId) {
|
public CorrosiveGale(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.keyword.ReachAbility;
|
import mage.abilities.keyword.ReachAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -50,7 +51,7 @@ public class SilklashSpider extends CardImpl<SilklashSpider> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public SilklashSpider(UUID ownerId) {
|
public SilklashSpider(UUID ownerId) {
|
||||||
|
|
|
@ -41,6 +41,7 @@ import mage.abilities.effects.common.DestroyTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetControlledCreaturePermanent;
|
import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -53,7 +54,7 @@ public class ElvishSkysweeper extends CardImpl<ElvishSkysweeper> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public ElvishSkysweeper(UUID ownerId) {
|
public ElvishSkysweeper(UUID ownerId) {
|
||||||
|
|
|
@ -29,14 +29,16 @@ package mage.sets.riseoftheeldrazi;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.Constants.CardType;
|
import mage.Constants.CardType;
|
||||||
|
import mage.Constants.Duration;
|
||||||
import mage.Constants.Rarity;
|
import mage.Constants.Rarity;
|
||||||
|
import mage.Constants.Zone;
|
||||||
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
|
import mage.abilities.effects.common.continious.BoostAllEffect;
|
||||||
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.filter.predicate.Predicates;
|
||||||
import mage.Constants.Duration;
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.abilities.effects.common.continious.BoostAllEffect;
|
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
|
||||||
import mage.Constants.Zone;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -48,9 +50,8 @@ public class GravitationalShift extends CardImpl<GravitationalShift> {
|
||||||
private final static FilterCreaturePermanent filter2 = new FilterCreaturePermanent("Creatures without flying");
|
private final static FilterCreaturePermanent filter2 = new FilterCreaturePermanent("Creatures without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter1.getAbilities().add(FlyingAbility.getInstance());
|
filter1.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
filter2.getAbilities().add(FlyingAbility.getInstance());
|
filter2.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter2.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public GravitationalShift(UUID ownerId) {
|
public GravitationalShift(UUID ownerId) {
|
||||||
|
|
|
@ -42,6 +42,7 @@ import mage.abilities.effects.common.DestroyTargetEffect;
|
||||||
import mage.abilities.keyword.DefenderAbility;
|
import mage.abilities.keyword.DefenderAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
@ -56,7 +57,7 @@ public class GrotagSiegeRunner extends CardImpl<GrotagSiegeRunner> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with defender");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with defender");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(DefenderAbility.getInstance());
|
filter.add(new AbilityPredicate(DefenderAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public GrotagSiegeRunner(UUID ownerId) {
|
public GrotagSiegeRunner(UUID ownerId) {
|
||||||
|
|
|
@ -34,6 +34,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,7 +46,7 @@ public class LeafArrow extends CardImpl<LeafArrow> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public LeafArrow(UUID ownerId) {
|
public LeafArrow(UUID ownerId) {
|
||||||
|
|
|
@ -37,6 +37,7 @@ import mage.abilities.keyword.DefenderAbility;
|
||||||
import mage.abilities.mana.DynamicManaAbility;
|
import mage.abilities.mana.DynamicManaAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -47,7 +48,7 @@ public class OvergrownBattlement extends CardImpl<OvergrownBattlement> {
|
||||||
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("creature with defender you control");
|
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("creature with defender you control");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(DefenderAbility.getInstance());
|
filter.add(new AbilityPredicate(DefenderAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public OvergrownBattlement(UUID ownerId) {
|
public OvergrownBattlement(UUID ownerId) {
|
||||||
|
|
|
@ -38,6 +38,7 @@ import mage.abilities.effects.common.continious.BoostControlledEffect;
|
||||||
import mage.abilities.keyword.DefenderAbility;
|
import mage.abilities.keyword.DefenderAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -48,7 +49,7 @@ public class StalwartShieldBearers extends CardImpl<StalwartShieldBearers> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with defender");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with defender");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(DefenderAbility.getInstance());
|
filter.add(new AbilityPredicate(DefenderAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public StalwartShieldBearers(UUID ownerId) {
|
public StalwartShieldBearers(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.DefenderAbility;
|
import mage.abilities.keyword.DefenderAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.TargetPlayer;
|
import mage.target.TargetPlayer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -49,7 +50,7 @@ import mage.target.TargetPlayer;
|
||||||
public class VentSentinel extends CardImpl<VentSentinel> {
|
public class VentSentinel extends CardImpl<VentSentinel> {
|
||||||
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("creatures with defender you control");
|
private static final FilterControlledCreaturePermanent filter = new FilterControlledCreaturePermanent("creatures with defender you control");
|
||||||
static{
|
static{
|
||||||
filter.getAbilities().add(DefenderAbility.getInstance());
|
filter.add(new AbilityPredicate(DefenderAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public VentSentinel(UUID ownerId) {
|
public VentSentinel(UUID ownerId) {
|
||||||
|
|
|
@ -38,6 +38,7 @@ import mage.abilities.effects.common.ReturnToHandTargetEffect;
|
||||||
import mage.abilities.keyword.InfectAbility;
|
import mage.abilities.keyword.InfectAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.FilterCard;
|
import mage.filter.FilterCard;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCardInYourGraveyard;
|
import mage.target.common.TargetCardInYourGraveyard;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -49,9 +50,7 @@ public class CorpseCur extends CardImpl<CorpseCur> {
|
||||||
private static final FilterCard filter = new FilterCard("creature card with infect from your graveyard");
|
private static final FilterCard filter = new FilterCard("creature card with infect from your graveyard");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(InfectAbility.getInstance());
|
filter.add(new AbilityPredicate(InfectAbility.class));
|
||||||
filter.setNotAbilities(false);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public CorpseCur (UUID ownerId) {
|
public CorpseCur (UUID ownerId) {
|
||||||
|
|
|
@ -45,6 +45,7 @@ import mage.abilities.effects.common.continious.BoostControlledEffect;
|
||||||
import mage.abilities.common.SpellCastTriggeredAbility;
|
import mage.abilities.common.SpellCastTriggeredAbility;
|
||||||
import mage.filter.Filter;
|
import mage.filter.Filter;
|
||||||
import mage.filter.FilterSpell;
|
import mage.filter.FilterSpell;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -56,9 +57,8 @@ public class HandOfThePraetors extends CardImpl<HandOfThePraetors> {
|
||||||
private static final FilterSpell filterSpell = new FilterSpell("a creature spell with infect");
|
private static final FilterSpell filterSpell = new FilterSpell("a creature spell with infect");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(InfectAbility.getInstance());
|
filter.add(new AbilityPredicate(InfectAbility.class));
|
||||||
filter.setNotAbilities(false);
|
filterSpell.add(new AbilityPredicate(InfectAbility.class));
|
||||||
filterSpell.getAbilities().add(InfectAbility.getInstance());
|
|
||||||
filterSpell.getCardType().add(CardType.CREATURE);
|
filterSpell.getCardType().add(CardType.CREATURE);
|
||||||
filterSpell.setScopeCardType(Filter.ComparisonScope.Any);
|
filterSpell.setScopeCardType(Filter.ComparisonScope.Any);
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,6 +36,7 @@ import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.target.common.TargetControlledCreaturePermanent;
|
import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
|
@ -50,7 +51,7 @@ public class WingPuncture extends CardImpl<WingPuncture> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public WingPuncture(UUID ownerId) {
|
public WingPuncture(UUID ownerId) {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Loki
|
* @author Loki
|
||||||
|
@ -44,7 +45,7 @@ public class NeedleStorm extends CardImpl<NeedleStorm> {
|
||||||
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private final static FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public NeedleStorm(UUID ownerId) {
|
public NeedleStorm(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterAttackingCreature;
|
import mage.filter.common.FilterAttackingCreature;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,7 +52,7 @@ public class FemerefArchers extends CardImpl<FemerefArchers> {
|
||||||
private final static FilterAttackingCreature filter = new FilterAttackingCreature("attacking creature with flying");
|
private final static FilterAttackingCreature filter = new FilterAttackingCreature("attacking creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public FemerefArchers(UUID ownerId) {
|
public FemerefArchers(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,8 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.mana.ColorlessManaAbility;
|
import mage.abilities.mana.ColorlessManaAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterAttackingCreature;
|
import mage.filter.common.FilterAttackingCreature;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,8 +53,7 @@ public class Quicksand extends CardImpl<Quicksand> {
|
||||||
private static final FilterAttackingCreature filter = new FilterAttackingCreature("attacking creature without flying");
|
private static final FilterAttackingCreature filter = new FilterAttackingCreature("attacking creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Quicksand(UUID ownerId) {
|
public Quicksand(UUID ownerId) {
|
||||||
|
|
|
@ -39,6 +39,8 @@ import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.abilities.keyword.IslandwalkAbility;
|
import mage.abilities.keyword.IslandwalkAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -50,8 +52,7 @@ public class MerfolkSeastalkers extends CardImpl<MerfolkSeastalkers> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public MerfolkSeastalkers(UUID ownerId) {
|
public MerfolkSeastalkers(UUID ownerId) {
|
||||||
|
|
|
@ -42,6 +42,7 @@ import mage.abilities.keyword.KickerAbility;
|
||||||
import mage.abilities.keyword.ReachAbility;
|
import mage.abilities.keyword.ReachAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -53,7 +54,7 @@ public class OranRiefRecluse extends CardImpl<OranRiefRecluse> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature with flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public OranRiefRecluse(UUID ownerId) {
|
public OranRiefRecluse(UUID ownerId) {
|
||||||
|
|
|
@ -34,6 +34,8 @@ import mage.abilities.effects.common.DamageAllEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -44,8 +46,7 @@ public class SeismicShudder extends CardImpl<SeismicShudder> {
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature without flying");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
filter.getAbilities().add(FlyingAbility.getInstance());
|
filter.add(Predicates.not(new AbilityPredicate(FlyingAbility.class)));
|
||||||
filter.setNotAbilities(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public SeismicShudder(UUID ownerId) {
|
public SeismicShudder(UUID ownerId) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ import mage.abilities.effects.common.DamageTargetEffect;
|
||||||
import mage.abilities.keyword.FlyingAbility;
|
import mage.abilities.keyword.FlyingAbility;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.filter.predicate.mageobject.SubtypePredicate;
|
import mage.filter.predicate.mageobject.SubtypePredicate;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
|
|
||||||
|
@ -55,7 +56,7 @@ public class TajuruArcher extends CardImpl<TajuruArcher> {
|
||||||
static {
|
static {
|
||||||
filter.add(new SubtypePredicate("Ally"));
|
filter.add(new SubtypePredicate("Ally"));
|
||||||
filter.setTargetController(Constants.TargetController.YOU);
|
filter.setTargetController(Constants.TargetController.YOU);
|
||||||
filterTarget.getAbilities().add(FlyingAbility.getInstance());
|
filterTarget.add(new AbilityPredicate(FlyingAbility.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
public TajuruArcher(UUID ownerId) {
|
public TajuruArcher(UUID ownerId) {
|
||||||
|
|
|
@ -31,10 +31,6 @@ package mage.filter;
|
||||||
import mage.Constants.CardType;
|
import mage.Constants.CardType;
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
import mage.ObjectColor;
|
import mage.ObjectColor;
|
||||||
import mage.abilities.Abilities;
|
|
||||||
import mage.abilities.AbilitiesImpl;
|
|
||||||
import mage.abilities.Ability;
|
|
||||||
import mage.abilities.keyword.ChangelingAbility;
|
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -46,8 +42,6 @@ import java.util.List;
|
||||||
* @author North
|
* @author North
|
||||||
*/
|
*/
|
||||||
public class FilterObject<E extends MageObject, T extends FilterObject<E, T>> extends FilterImpl<E, T> implements Filter<E> {
|
public class FilterObject<E extends MageObject, T extends FilterObject<E, T>> extends FilterImpl<E, T> implements Filter<E> {
|
||||||
protected Abilities<Ability> abilities;
|
|
||||||
protected boolean notAbilities;
|
|
||||||
protected List<CardType> cardType = new ArrayList<CardType>();
|
protected List<CardType> cardType = new ArrayList<CardType>();
|
||||||
protected ComparisonScope scopeCardType = ComparisonScope.Any;
|
protected ComparisonScope scopeCardType = ComparisonScope.Any;
|
||||||
protected List<CardType> notCardType = new ArrayList<CardType>();
|
protected List<CardType> notCardType = new ArrayList<CardType>();
|
||||||
|
@ -71,14 +65,11 @@ public class FilterObject<E extends MageObject, T extends FilterObject<E, T>> ex
|
||||||
|
|
||||||
public FilterObject(String name) {
|
public FilterObject(String name) {
|
||||||
super(name);
|
super(name);
|
||||||
abilities = new AbilitiesImpl<Ability>();
|
|
||||||
color = new ObjectColor();
|
color = new ObjectColor();
|
||||||
}
|
}
|
||||||
|
|
||||||
public FilterObject(FilterObject filter) {
|
public FilterObject(FilterObject filter) {
|
||||||
super(filter);
|
super(filter);
|
||||||
this.abilities = filter.abilities.copy();
|
|
||||||
this.notAbilities = filter.notAbilities;
|
|
||||||
this.cardType.addAll(filter.cardType);
|
this.cardType.addAll(filter.cardType);
|
||||||
this.notCardType.addAll(filter.notCardType);
|
this.notCardType.addAll(filter.notCardType);
|
||||||
this.scopeCardType = filter.scopeCardType;
|
this.scopeCardType = filter.scopeCardType;
|
||||||
|
@ -129,31 +120,9 @@ public class FilterObject<E extends MageObject, T extends FilterObject<E, T>> ex
|
||||||
return notFilter;
|
return notFilter;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (abilities.size() > 0) {
|
|
||||||
List<Ability> test = new ArrayList<Ability>(abilities);
|
|
||||||
for (Ability ability: object.getAbilities()) {
|
|
||||||
for (Ability abilityTest: test) {
|
|
||||||
if (ability == abilityTest || ability.getClass().equals(abilityTest.getClass())) {
|
|
||||||
test.remove(abilityTest);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (test.isEmpty() == notAbilities)
|
|
||||||
return notFilter;
|
|
||||||
}
|
|
||||||
|
|
||||||
return !notFilter;
|
return !notFilter;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Abilities getAbilities() {
|
|
||||||
return this.abilities;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setNotAbilities(boolean notAbilities) {
|
|
||||||
this.notAbilities = notAbilities;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<CardType> getCardType() {
|
public List<CardType> getCardType() {
|
||||||
return this.cardType;
|
return this.cardType;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,8 @@
|
||||||
package mage.filter.common;
|
package mage.filter.common;
|
||||||
|
|
||||||
import mage.abilities.keyword.DefenderAbility;
|
import mage.abilities.keyword.DefenderAbility;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.AbilityPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
|
|
||||||
|
@ -50,8 +52,7 @@ public class FilterCreatureForAttack extends FilterCreaturePermanent<FilterCreat
|
||||||
this.useBlocking = true;
|
this.useBlocking = true;
|
||||||
this.tapped = false;
|
this.tapped = false;
|
||||||
this.useTapped = true;
|
this.useTapped = true;
|
||||||
this.abilities.add(DefenderAbility.getInstance());
|
this.add(Predicates.not(new AbilityPredicate(DefenderAbility.class)));
|
||||||
this.notAbilities = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public FilterCreatureForAttack(final FilterCreatureForAttack filter) {
|
public FilterCreatureForAttack(final FilterCreatureForAttack filter) {
|
||||||
|
|
Loading…
Reference in a new issue