mirror of
https://github.com/correl/mage.git
synced 2025-01-13 11:01:58 +00:00
* 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:
parent
6405c8d2f0
commit
0e64df5d93
2 changed files with 6 additions and 6 deletions
|
@ -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.
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in a new issue