mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
Fix Tazeem Plane
This commit is contained in:
parent
5746a40ad2
commit
a08aeb6141
1 changed files with 52 additions and 5 deletions
|
@ -30,21 +30,24 @@ package mage.game.command.planes;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.Mode;
|
||||||
import mage.abilities.common.ActivateIfConditionActivatedAbility;
|
import mage.abilities.common.ActivateIfConditionActivatedAbility;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
import mage.abilities.condition.common.MainPhaseStackEmptyCondition;
|
import mage.abilities.condition.common.MainPhaseStackEmptyCondition;
|
||||||
import mage.abilities.costs.mana.GenericManaCost;
|
import mage.abilities.costs.mana.GenericManaCost;
|
||||||
import mage.abilities.dynamicvalue.common.PermanentsOnBattlefieldCount;
|
import mage.abilities.dynamicvalue.common.PermanentsOnBattlefieldCount;
|
||||||
import mage.abilities.effects.Effect;
|
import mage.abilities.effects.Effect;
|
||||||
|
import mage.abilities.effects.RestrictionEffect;
|
||||||
import mage.abilities.effects.common.DrawCardSourceControllerEffect;
|
import mage.abilities.effects.common.DrawCardSourceControllerEffect;
|
||||||
import mage.abilities.effects.common.RollPlanarDieEffect;
|
import mage.abilities.effects.common.RollPlanarDieEffect;
|
||||||
import mage.abilities.effects.common.combat.CantBlockAllEffect;
|
|
||||||
import mage.constants.Duration;
|
import mage.constants.Duration;
|
||||||
import mage.constants.TargetController;
|
import mage.constants.TargetController;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.filter.StaticFilters;
|
|
||||||
import mage.filter.common.FilterControlledLandPermanent;
|
import mage.filter.common.FilterControlledLandPermanent;
|
||||||
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
|
import mage.game.Game;
|
||||||
import mage.game.command.Plane;
|
import mage.game.command.Plane;
|
||||||
|
import mage.game.permanent.Permanent;
|
||||||
import mage.target.Target;
|
import mage.target.Target;
|
||||||
import mage.watchers.common.PlanarRollWatcher;
|
import mage.watchers.common.PlanarRollWatcher;
|
||||||
|
|
||||||
|
@ -54,22 +57,24 @@ import mage.watchers.common.PlanarRollWatcher;
|
||||||
*/
|
*/
|
||||||
public class TazeemPlane extends Plane {
|
public class TazeemPlane extends Plane {
|
||||||
|
|
||||||
|
private static final String rule = "Creatures can't block";
|
||||||
|
|
||||||
public TazeemPlane() {
|
public TazeemPlane() {
|
||||||
this.setName("Plane - Tazeem");
|
this.setName("Plane - Tazeem");
|
||||||
this.setExpansionSetCodeForImage("PCA");
|
this.setExpansionSetCodeForImage("PCA");
|
||||||
|
|
||||||
// Creatures can't block
|
// Creatures can't block
|
||||||
Ability ability = new SimpleStaticAbility(Zone.BATTLEFIELD, new CantBlockAllEffect(StaticFilters.FILTER_PERMANENT_CREATURES, Duration.WhileOnBattlefield));
|
Ability ability = new SimpleStaticAbility(Zone.COMMAND, new TazeemCantBlockAllEffect());
|
||||||
this.getAbilities().add(ability);
|
this.getAbilities().add(ability);
|
||||||
|
|
||||||
// Active player can roll the planar die: Whenever you roll {CHAOS}, draw a card for each land you control
|
// Active player can roll the planar die: Whenever you roll {CHAOS}, draw a card for each land you control
|
||||||
Effect chaosEffect = new DrawCardSourceControllerEffect(new PermanentsOnBattlefieldCount(new FilterControlledLandPermanent()));
|
Effect chaosEffect = new DrawCardSourceControllerEffect(new PermanentsOnBattlefieldCount(new FilterControlledLandPermanent()));
|
||||||
Target chaosTarget = null;
|
Target chaosTarget = null;
|
||||||
|
|
||||||
List<Effect> chaosEffects = new ArrayList<Effect>();
|
List<Effect> chaosEffects = new ArrayList<>();
|
||||||
chaosEffects.add(chaosEffect);
|
chaosEffects.add(chaosEffect);
|
||||||
|
|
||||||
List<Target> chaosTargets = new ArrayList<Target>();
|
List<Target> chaosTargets = new ArrayList<>();
|
||||||
chaosTargets.add(chaosTarget);
|
chaosTargets.add(chaosTarget);
|
||||||
|
|
||||||
ActivateIfConditionActivatedAbility chaosAbility = new ActivateIfConditionActivatedAbility(Zone.COMMAND, new RollPlanarDieEffect(chaosEffects, chaosTargets), new GenericManaCost(0), MainPhaseStackEmptyCondition.instance);
|
ActivateIfConditionActivatedAbility chaosAbility = new ActivateIfConditionActivatedAbility(Zone.COMMAND, new RollPlanarDieEffect(chaosEffects, chaosTargets), new GenericManaCost(0), MainPhaseStackEmptyCondition.instance);
|
||||||
|
@ -79,3 +84,45 @@ public class TazeemPlane extends Plane {
|
||||||
this.getAbilities().add(new SimpleStaticAbility(Zone.ALL, new PlanarDieRollCostIncreasingEffect(chaosAbility.getOriginalId())));
|
this.getAbilities().add(new SimpleStaticAbility(Zone.ALL, new PlanarDieRollCostIncreasingEffect(chaosAbility.getOriginalId())));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class TazeemCantBlockAllEffect extends RestrictionEffect {
|
||||||
|
|
||||||
|
private FilterCreaturePermanent filter = new FilterCreaturePermanent("Creatures");
|
||||||
|
|
||||||
|
public TazeemCantBlockAllEffect() {
|
||||||
|
super(Duration.Custom);
|
||||||
|
this.filter = filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TazeemCantBlockAllEffect(final TazeemCantBlockAllEffect effect) {
|
||||||
|
super(effect);
|
||||||
|
this.filter = effect.filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean applies(Permanent permanent, Ability source, Game game) {
|
||||||
|
Plane cPlane = game.getState().getCurrentPlane();
|
||||||
|
|
||||||
|
if (cPlane == null || !cPlane.getName().equalsIgnoreCase("Plane - Tazeem")) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return filter.match(permanent, source.getSourceId(), source.getControllerId(), game);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canBlock(Permanent attacker, Permanent blocker, Ability source, Game game) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TazeemCantBlockAllEffect copy() {
|
||||||
|
return new TazeemCantBlockAllEffect(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getText(Mode mode) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append(filter.getMessage()).append(" can't block");
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue