mirror of
https://github.com/magefree/mage.git
synced 2025-12-29 23:12:10 -08:00
[DFT] Implement Cloudspire Captain
This commit is contained in:
parent
59115c631e
commit
4b5bf3e1de
8 changed files with 140 additions and 20 deletions
|
|
@ -10,11 +10,7 @@ import mage.constants.Zone;
|
|||
public class CrewIncreasedPowerAbility extends StaticAbility {
|
||||
|
||||
public CrewIncreasedPowerAbility() {
|
||||
this("{this}");
|
||||
}
|
||||
|
||||
public CrewIncreasedPowerAbility(String selfName) {
|
||||
super(Zone.BATTLEFIELD, new InfoEffect(selfName + " crews Vehicles as though its power were 2 greater."));
|
||||
super(Zone.BATTLEFIELD, new InfoEffect("this creature crews Vehicles as though its power were 2 greater."));
|
||||
}
|
||||
|
||||
private CrewIncreasedPowerAbility(final CrewIncreasedPowerAbility ability) {
|
||||
|
|
|
|||
|
|
@ -0,0 +1,24 @@
|
|||
package mage.abilities.common;
|
||||
|
||||
import mage.abilities.StaticAbility;
|
||||
import mage.abilities.effects.common.InfoEffect;
|
||||
import mage.constants.Zone;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
public class CrewSaddleIncreasedPowerAbility extends StaticAbility {
|
||||
|
||||
public CrewSaddleIncreasedPowerAbility() {
|
||||
super(Zone.BATTLEFIELD, new InfoEffect("this creature saddles Mounts and crews Vehicles as though its power were 2 greater."));
|
||||
}
|
||||
|
||||
private CrewSaddleIncreasedPowerAbility(final CrewSaddleIncreasedPowerAbility ability) {
|
||||
super(ability);
|
||||
}
|
||||
|
||||
@Override
|
||||
public CrewSaddleIncreasedPowerAbility copy() {
|
||||
return new CrewSaddleIncreasedPowerAbility(this);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,37 @@
|
|||
package mage.abilities.common;
|
||||
|
||||
import mage.abilities.MageSingleton;
|
||||
import mage.abilities.StaticAbility;
|
||||
import mage.abilities.effects.common.InfoEffect;
|
||||
import mage.constants.Zone;
|
||||
|
||||
import java.io.ObjectStreamException;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
public class CrewSaddleWithToughnessAbility extends StaticAbility implements MageSingleton {
|
||||
|
||||
private static final CrewSaddleWithToughnessAbility instance;
|
||||
|
||||
static {
|
||||
instance = new CrewSaddleWithToughnessAbility();
|
||||
}
|
||||
|
||||
private Object readResolve() throws ObjectStreamException {
|
||||
return instance;
|
||||
}
|
||||
|
||||
public static CrewSaddleWithToughnessAbility getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
private CrewSaddleWithToughnessAbility() {
|
||||
super(Zone.BATTLEFIELD, new InfoEffect("{this} saddles Mounts and crews Vehicles using its toughness rather than its power."));
|
||||
}
|
||||
|
||||
@Override
|
||||
public CrewSaddleWithToughnessAbility copy() {
|
||||
return instance;
|
||||
}
|
||||
}
|
||||
|
|
@ -1,10 +1,7 @@
|
|||
package mage.abilities.keyword;
|
||||
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.common.CrewIncreasedPowerAbility;
|
||||
import mage.abilities.common.CrewWithToughnessAbility;
|
||||
import mage.abilities.common.SimpleActivatedAbility;
|
||||
import mage.abilities.common.SimpleStaticAbility;
|
||||
import mage.abilities.common.*;
|
||||
import mage.abilities.costs.Cost;
|
||||
import mage.abilities.costs.CostImpl;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
|
|
@ -156,7 +153,7 @@ class CrewCost extends CostImpl {
|
|||
int selectedPower = this.targets.keySet().stream()
|
||||
.map(game::getPermanent)
|
||||
.filter(Objects::nonNull)
|
||||
.mapToInt(p -> (getCrewPower(p, game)))
|
||||
.mapToInt(p -> getCrewPower(p, game))
|
||||
.sum();
|
||||
String extraInfo = "(selected power " + selectedPower + " of " + value + ")";
|
||||
if (selectedPower >= value) {
|
||||
|
|
@ -215,10 +212,12 @@ class CrewCost extends CostImpl {
|
|||
return new CrewCost(this);
|
||||
}
|
||||
|
||||
private int getCrewPower(Permanent permanent, Game game) {
|
||||
if (permanent.hasAbility(CrewWithToughnessAbility.getInstance(), game)) {
|
||||
private static int getCrewPower(Permanent permanent, Game game) {
|
||||
if (permanent.hasAbility(CrewWithToughnessAbility.getInstance(), game)
|
||||
|| permanent.hasAbility(CrewSaddleWithToughnessAbility.getInstance(), game)) {
|
||||
return permanent.getToughness().getValue();
|
||||
} else if (permanent.getAbilities(game).containsClass(CrewIncreasedPowerAbility.class)) {
|
||||
} else if (permanent.getAbilities(game).containsClass(CrewIncreasedPowerAbility.class)
|
||||
|| permanent.getAbilities(game).containsClass(CrewSaddleIncreasedPowerAbility.class)) {
|
||||
return permanent.getPower().getValue() + 2;
|
||||
} else {
|
||||
return permanent.getPower().getValue();
|
||||
|
|
|
|||
|
|
@ -1,8 +1,8 @@
|
|||
package mage.abilities.keyword;
|
||||
|
||||
import mage.MageInt;
|
||||
import mage.MageObject;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.common.CrewSaddleIncreasedPowerAbility;
|
||||
import mage.abilities.common.CrewSaddleWithToughnessAbility;
|
||||
import mage.abilities.common.SimpleActivatedAbility;
|
||||
import mage.abilities.condition.common.SaddledCondition;
|
||||
import mage.abilities.costs.Cost;
|
||||
|
|
@ -118,8 +118,7 @@ class SaddleCost extends CostImpl {
|
|||
int selectedPower = this.targets.keySet().stream()
|
||||
.map(game::getPermanent)
|
||||
.filter(Objects::nonNull)
|
||||
.map(MageObject::getPower)
|
||||
.mapToInt(MageInt::getValue)
|
||||
.mapToInt(p -> getSaddlePower(p, game))
|
||||
.sum();
|
||||
String extraInfo = "(selected power " + selectedPower + " of " + value + ")";
|
||||
if (selectedPower >= value) {
|
||||
|
|
@ -137,7 +136,7 @@ class SaddleCost extends CostImpl {
|
|||
if (!game.replaceEvent(event)) {
|
||||
Permanent permanent = game.getPermanent(targetId);
|
||||
if (permanent != null && permanent.tap(source, game)) {
|
||||
sumPower += permanent.getPower().getValue();
|
||||
sumPower += getSaddlePower(permanent, game);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -158,7 +157,7 @@ class SaddleCost extends CostImpl {
|
|||
public boolean canPay(Ability ability, Ability source, UUID controllerId, Game game) {
|
||||
int sumPower = 0;
|
||||
for (Permanent permanent : game.getBattlefield().getAllActivePermanents(filter, controllerId, game)) {
|
||||
sumPower += Math.max(permanent.getPower().getValue(), 0);
|
||||
sumPower += Math.max(getSaddlePower(permanent, game), 0);
|
||||
if (sumPower >= value) {
|
||||
return true;
|
||||
}
|
||||
|
|
@ -170,4 +169,14 @@ class SaddleCost extends CostImpl {
|
|||
public SaddleCost copy() {
|
||||
return new SaddleCost(this);
|
||||
}
|
||||
|
||||
private static int getSaddlePower(Permanent permanent, Game game) {
|
||||
if (permanent.hasAbility(CrewSaddleWithToughnessAbility.getInstance(), game)) {
|
||||
return permanent.getToughness().getValue();
|
||||
} else if (permanent.getAbilities(game).containsClass(CrewSaddleIncreasedPowerAbility.class)) {
|
||||
return permanent.getPower().getValue() + 2;
|
||||
} else {
|
||||
return permanent.getPower().getValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -16,7 +16,7 @@ public final class PilotToken extends TokenImpl {
|
|||
subtype.add(SubType.PILOT);
|
||||
power = new MageInt(1);
|
||||
toughness = new MageInt(1);
|
||||
addAbility(new CrewIncreasedPowerAbility("this creature"));
|
||||
addAbility(new CrewIncreasedPowerAbility());
|
||||
}
|
||||
|
||||
private PilotToken(final PilotToken token) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue