mirror of
https://github.com/correl/mage.git
synced 2025-01-13 19:11:33 +00:00
Added max targets limit support in TargetAmount
This commit is contained in:
parent
2daa9b6004
commit
bad26b182a
2 changed files with 43 additions and 3 deletions
|
@ -21,16 +21,24 @@ public class TargetAnyTargetAmount extends TargetPermanentOrPlayerAmount {
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetAnyTargetAmount(int amount) {
|
public TargetAnyTargetAmount(int amount) {
|
||||||
|
this(amount, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public TargetAnyTargetAmount(int amount, int maxNumberOfTargets) {
|
||||||
// 107.1c If a rule or ability instructs a player to choose “any number,” that player may choose
|
// 107.1c If a rule or ability instructs a player to choose “any number,” that player may choose
|
||||||
// any positive number or zero, unless something (such as damage or counters) is being divided
|
// any positive number or zero, unless something (such as damage or counters) is being divided
|
||||||
// or distributed among “any number” of players and/or objects. In that case, a nonzero number
|
// or distributed among “any number” of players and/or objects. In that case, a nonzero number
|
||||||
// of players and/or objects must be chosen if possible.
|
// of players and/or objects must be chosen if possible.
|
||||||
this(new StaticValue(amount));
|
this(new StaticValue(amount), maxNumberOfTargets);
|
||||||
this.minNumberOfTargets = 1;
|
this.minNumberOfTargets = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TargetAnyTargetAmount(DynamicValue amount) {
|
public TargetAnyTargetAmount(DynamicValue amount) {
|
||||||
super(amount);
|
this(amount, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public TargetAnyTargetAmount(DynamicValue amount, int maxNumberOfTargets) {
|
||||||
|
super(amount, maxNumberOfTargets);
|
||||||
this.zone = Zone.ALL;
|
this.zone = Zone.ALL;
|
||||||
this.filter = defaultFilter;
|
this.filter = defaultFilter;
|
||||||
this.targetName = filter.getMessage();
|
this.targetName = filter.getMessage();
|
||||||
|
|
|
@ -4,7 +4,6 @@ import mage.MageObject;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.dynamicvalue.DynamicValue;
|
import mage.abilities.dynamicvalue.DynamicValue;
|
||||||
import mage.filter.Filter;
|
import mage.filter.Filter;
|
||||||
import mage.filter.StaticFilters;
|
|
||||||
import mage.filter.common.FilterPermanentOrPlayer;
|
import mage.filter.common.FilterPermanentOrPlayer;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
|
@ -24,7 +23,12 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
protected FilterPermanentOrPlayer filter;
|
protected FilterPermanentOrPlayer filter;
|
||||||
|
|
||||||
TargetPermanentOrPlayerAmount(DynamicValue amount) {
|
TargetPermanentOrPlayerAmount(DynamicValue amount) {
|
||||||
|
this(amount, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TargetPermanentOrPlayerAmount(DynamicValue amount, int maxNumberOfTargets) {
|
||||||
super(amount);
|
super(amount);
|
||||||
|
this.maxNumberOfTargets = maxNumberOfTargets;
|
||||||
}
|
}
|
||||||
|
|
||||||
TargetPermanentOrPlayerAmount(final TargetPermanentOrPlayerAmount target) {
|
TargetPermanentOrPlayerAmount(final TargetPermanentOrPlayerAmount target) {
|
||||||
|
@ -39,6 +43,12 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canTarget(UUID objectId, Game game) {
|
public boolean canTarget(UUID objectId, Game game) {
|
||||||
|
|
||||||
|
// max targets limit reached (only selected can be choosen again)
|
||||||
|
if (getMaxNumberOfTargets() > 0 && getTargets().size() >= getMaxNumberOfTargets()) {
|
||||||
|
return getTargets().contains(objectId);
|
||||||
|
}
|
||||||
|
|
||||||
Permanent permanent = game.getPermanent(objectId);
|
Permanent permanent = game.getPermanent(objectId);
|
||||||
if (permanent != null) {
|
if (permanent != null) {
|
||||||
return filter.match(permanent, game);
|
return filter.match(permanent, game);
|
||||||
|
@ -49,6 +59,12 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canTarget(UUID objectId, Ability source, Game game) {
|
public boolean canTarget(UUID objectId, Ability source, Game game) {
|
||||||
|
|
||||||
|
// max targets limit reached (only selected can be choosen again)
|
||||||
|
if (getMaxNumberOfTargets() > 0 && getTargets().size() >= getMaxNumberOfTargets()) {
|
||||||
|
return getTargets().contains(objectId);
|
||||||
|
}
|
||||||
|
|
||||||
Permanent permanent = game.getPermanent(objectId);
|
Permanent permanent = game.getPermanent(objectId);
|
||||||
Player player = game.getPlayer(objectId);
|
Player player = game.getPlayer(objectId);
|
||||||
|
|
||||||
|
@ -77,6 +93,7 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canChoose(UUID sourceId, UUID sourceControllerId, Game game) {
|
public boolean canChoose(UUID sourceId, UUID sourceControllerId, Game game) {
|
||||||
|
// no max targets limit here
|
||||||
int count = 0;
|
int count = 0;
|
||||||
MageObject targetSource = game.getObject(sourceId);
|
MageObject targetSource = game.getObject(sourceId);
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(sourceControllerId, game)) {
|
for (UUID playerId : game.getState().getPlayersInRange(sourceControllerId, game)) {
|
||||||
|
@ -105,6 +122,7 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canChoose(UUID sourceControllerId, Game game) {
|
public boolean canChoose(UUID sourceControllerId, Game game) {
|
||||||
|
// no max targets limit here
|
||||||
int count = 0;
|
int count = 0;
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(sourceControllerId, game)) {
|
for (UUID playerId : game.getState().getPlayersInRange(sourceControllerId, game)) {
|
||||||
Player player = game.getPlayer(playerId);
|
Player player = game.getPlayer(playerId);
|
||||||
|
@ -128,6 +146,13 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
@Override
|
@Override
|
||||||
public Set<UUID> possibleTargets(UUID sourceId, UUID sourceControllerId, Game game) {
|
public Set<UUID> possibleTargets(UUID sourceId, UUID sourceControllerId, Game game) {
|
||||||
Set<UUID> possibleTargets = new HashSet<>();
|
Set<UUID> possibleTargets = new HashSet<>();
|
||||||
|
|
||||||
|
// max targets limit reached (only selected can be choosen again)
|
||||||
|
if (getMaxNumberOfTargets() > 0 && getTargets().size() >= getMaxNumberOfTargets()) {
|
||||||
|
possibleTargets.addAll(getTargets());
|
||||||
|
return possibleTargets;
|
||||||
|
}
|
||||||
|
|
||||||
MageObject targetSource = game.getObject(sourceId);
|
MageObject targetSource = game.getObject(sourceId);
|
||||||
|
|
||||||
game.getState()
|
game.getState()
|
||||||
|
@ -155,6 +180,13 @@ public abstract class TargetPermanentOrPlayerAmount extends TargetAmount {
|
||||||
@Override
|
@Override
|
||||||
public Set<UUID> possibleTargets(UUID sourceControllerId, Game game) {
|
public Set<UUID> possibleTargets(UUID sourceControllerId, Game game) {
|
||||||
Set<UUID> possibleTargets = new HashSet<>();
|
Set<UUID> possibleTargets = new HashSet<>();
|
||||||
|
|
||||||
|
// max targets limit reached (only selected can be choosen again)
|
||||||
|
if (getMaxNumberOfTargets() > 0 && getTargets().size() >= getMaxNumberOfTargets()) {
|
||||||
|
possibleTargets.addAll(getTargets());
|
||||||
|
return possibleTargets;
|
||||||
|
}
|
||||||
|
|
||||||
game.getState()
|
game.getState()
|
||||||
.getPlayersInRange(sourceControllerId, game)
|
.getPlayersInRange(sourceControllerId, game)
|
||||||
.stream()
|
.stream()
|
||||||
|
|
Loading…
Reference in a new issue