[BRC] Implement Ashnod, the Uncaring

This commit is contained in:
Evan Kranzler 2022-11-06 12:24:44 -05:00
parent 8b52789b52
commit cf9a4a4eab
9 changed files with 132 additions and 16 deletions

View file

@ -0,0 +1,9 @@
package mage.abilities.costs;
/**
* An interface to identify costs that sacrifice permanents
*
* @author TheElk801
*/
public interface SacrificeCost extends Cost {
}

View file

@ -1,23 +1,23 @@
package mage.abilities.costs.common;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import mage.abilities.Ability;
import mage.abilities.ActivatedAbilityImpl;
import mage.abilities.costs.Cost;
import mage.abilities.costs.CostImpl;
import mage.abilities.costs.SacrificeCost;
import mage.constants.AbilityType;
import mage.filter.FilterPermanent;
import mage.game.Game;
import mage.game.permanent.Permanent;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
/**
*
* @author LevelX2
*/
public class SacrificeAllCost extends CostImpl {
public class SacrificeAllCost extends CostImpl implements SacrificeCost {
private final FilterPermanent filter;
private final List<Permanent> permanents = new ArrayList<>();

View file

@ -1,18 +1,18 @@
package mage.abilities.costs.common;
import java.util.UUID;
import mage.abilities.Ability;
import mage.abilities.costs.Cost;
import mage.abilities.costs.CostImpl;
import mage.abilities.costs.SacrificeCost;
import mage.game.Game;
import mage.game.permanent.Permanent;
import java.util.UUID;
/**
*
* @author L_J (based on BetaSteward_at_googlemail.com)
*/
public class SacrificeAttachedCost extends CostImpl {
public class SacrificeAttachedCost extends CostImpl implements SacrificeCost {
public SacrificeAttachedCost() {
this.text = "Sacrifice enchanted creature";

View file

@ -2,6 +2,7 @@ package mage.abilities.costs.common;
import mage.abilities.Ability;
import mage.abilities.costs.Cost;
import mage.abilities.costs.SacrificeCost;
import mage.abilities.costs.UseAttachedCost;
import mage.game.Game;
import mage.game.permanent.Permanent;
@ -11,7 +12,7 @@ import java.util.UUID;
/**
* @author TheElk801
*/
public class SacrificeAttachmentCost extends UseAttachedCost {
public class SacrificeAttachmentCost extends UseAttachedCost implements SacrificeCost {
public SacrificeAttachmentCost() {
super();

View file

@ -1,18 +1,19 @@
package mage.abilities.costs.common;
import java.util.UUID;
import mage.abilities.Ability;
import mage.abilities.costs.Cost;
import mage.abilities.costs.CostImpl;
import mage.abilities.costs.SacrificeCost;
import mage.game.Game;
import mage.game.permanent.Permanent;
import java.util.UUID;
/**
*
* @author BetaSteward_at_googlemail.com
*/
public class SacrificeSourceCost extends CostImpl {
public class SacrificeSourceCost extends CostImpl implements SacrificeCost {
public SacrificeSourceCost() {
this.text = "sacrifice {this}";

View file

@ -4,6 +4,7 @@ import mage.abilities.Ability;
import mage.abilities.ActivatedAbilityImpl;
import mage.abilities.costs.Cost;
import mage.abilities.costs.CostImpl;
import mage.abilities.costs.SacrificeCost;
import mage.constants.AbilityType;
import mage.constants.Outcome;
import mage.filter.common.FilterControlledPermanent;
@ -19,7 +20,7 @@ import java.util.UUID;
/**
* @author BetaSteward_at_googlemail.com
*/
public class SacrificeTargetCost extends CostImpl {
public class SacrificeTargetCost extends CostImpl implements SacrificeCost {
private final List<Permanent> permanents = new ArrayList<>();

View file

@ -2,6 +2,7 @@ package mage.abilities.costs.common;
import mage.abilities.Ability;
import mage.abilities.costs.Cost;
import mage.abilities.costs.SacrificeCost;
import mage.abilities.costs.VariableCostImpl;
import mage.abilities.costs.VariableCostType;
import mage.filter.Filter;
@ -12,7 +13,7 @@ import mage.target.common.TargetControlledPermanent;
/**
* @author LevelX2
*/
public class SacrificeXTargetCost extends VariableCostImpl {
public class SacrificeXTargetCost extends VariableCostImpl implements SacrificeCost {
protected final FilterControlledPermanent filter;
private final int minValue;