* Fixed a bug that tap enchanted effect did not work because causing enchantment was already gone. Fixed a bug of SacrificeEffect of handling static filter.

This commit is contained in:
LevelX2 2015-03-29 22:44:46 +02:00
parent 6405c8d2f0
commit 0e64df5d93
2 changed files with 6 additions and 6 deletions

View file

@ -32,9 +32,8 @@ import mage.abilities.Ability;
import mage.abilities.dynamicvalue.DynamicValue; import mage.abilities.dynamicvalue.DynamicValue;
import mage.abilities.dynamicvalue.common.StaticValue; import mage.abilities.dynamicvalue.common.StaticValue;
import mage.abilities.effects.OneShotEffect; import mage.abilities.effects.OneShotEffect;
import mage.constants.TargetController;
import mage.filter.FilterPermanent; import mage.filter.FilterPermanent;
import mage.filter.predicate.permanent.ControllerPredicate; import mage.filter.predicate.permanent.ControllerIdPredicate;
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;
@ -79,13 +78,14 @@ public class SacrificeEffect extends OneShotEffect{
return false; return false;
} }
filter.add(new ControllerPredicate(TargetController.YOU)); FilterPermanent newFilter = filter.copy(); // filter can be static, so it's important to copy here
newFilter.add(new ControllerIdPredicate(player.getId()));
int amount = count.calculate(game, source, this); int amount = count.calculate(game, source, this);
int realCount = game.getBattlefield().countAll(filter, player.getId(), game); int realCount = game.getBattlefield().countAll(newFilter, player.getId(), game);
amount = Math.min(amount, realCount); amount = Math.min(amount, realCount);
Target target = new TargetPermanent(amount, amount, filter, true); Target target = new TargetPermanent(amount, amount, newFilter, true);
// A spell or ability could have removed the only legal target this player // A spell or ability could have removed the only legal target this player
// had, if thats the case this ability should fizzle. // had, if thats the case this ability should fizzle.

View file

@ -51,7 +51,7 @@ public class TapEnchantedEffect extends OneShotEffect {
@Override @Override
public boolean apply(Game game, Ability source) { public boolean apply(Game game, Ability source) {
Permanent permanent = game.getPermanent(source.getSourceId()); Permanent permanent = (Permanent) source.getSourceObject(game);
if (permanent != null) { if (permanent != null) {
Permanent attach = game.getPermanent(permanent.getAttachedTo()); Permanent attach = game.getPermanent(permanent.getAttachedTo());
if (attach != null) { if (attach != null) {