mirror of
https://github.com/magefree/mage.git
synced 2026-01-09 12:22:10 -08:00
[FRF] Added Brutal Hordechief and Crucible of the Spirit Dragon. FRF Complete!!!
This commit is contained in:
parent
1d584afb4f
commit
de10554ec4
9 changed files with 451 additions and 36 deletions
|
|
@ -29,6 +29,8 @@ package mage.abilities.effects.common;
|
|||
|
||||
import mage.Mana;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.dynamicvalue.DynamicValue;
|
||||
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||
import mage.abilities.mana.builder.ConditionalManaBuilder;
|
||||
import mage.choices.ChoiceColor;
|
||||
import mage.game.Game;
|
||||
|
|
@ -39,20 +41,34 @@ import mage.players.Player;
|
|||
*/
|
||||
public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
|
||||
|
||||
private final int amount;
|
||||
private final DynamicValue amount;
|
||||
private final ConditionalManaBuilder manaBuilder;
|
||||
private final boolean oneChoice;
|
||||
|
||||
public AddConditionalManaOfAnyColorEffect(int amount, ConditionalManaBuilder manaBuilder) {
|
||||
this(new StaticValue(amount), manaBuilder);
|
||||
}
|
||||
|
||||
public AddConditionalManaOfAnyColorEffect(DynamicValue amount, ConditionalManaBuilder manaBuilder) {
|
||||
this(amount, manaBuilder, true);
|
||||
}
|
||||
|
||||
public AddConditionalManaOfAnyColorEffect(DynamicValue amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
|
||||
super();
|
||||
this.amount = amount;
|
||||
this.manaBuilder = manaBuilder;
|
||||
staticText = "Add " + amount + " mana of any one color to your mana pool. " + manaBuilder.getRule();
|
||||
this.oneChoice = oneChoice;
|
||||
//
|
||||
staticText = "Add " + amount + " mana of " +
|
||||
(oneChoice ? "any one color":"in any combination of colors") +
|
||||
" to your mana pool. " + manaBuilder.getRule();
|
||||
}
|
||||
|
||||
public AddConditionalManaOfAnyColorEffect(final AddConditionalManaOfAnyColorEffect effect) {
|
||||
super(effect);
|
||||
this.amount = effect.amount;
|
||||
this.manaBuilder = effect.manaBuilder;
|
||||
this.oneChoice = effect.oneChoice;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
@ -62,15 +78,20 @@ public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
|
|||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Player player = game.getPlayer(source.getControllerId());
|
||||
if (player == null) {
|
||||
Player controller = game.getPlayer(source.getControllerId());
|
||||
if (controller == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
int value = amount.calculate(game, source, this);
|
||||
boolean result = false;
|
||||
for (int i = 0; i < amount; i++) {
|
||||
ChoiceColor choice = (ChoiceColor) source.getChoices().get(i);
|
||||
|
||||
ChoiceColor choice = new ChoiceColor();
|
||||
for (int i = 0; i < value; i++) {
|
||||
if (!choice.isChosen()) {
|
||||
if (!controller.choose(outcome, choice, game)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
Mana mana = null;
|
||||
if (choice.getColor().isBlack()) {
|
||||
mana = manaBuilder.setMana(Mana.BlackMana(1), source, game).build();
|
||||
|
|
@ -85,10 +106,12 @@ public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
|
|||
}
|
||||
|
||||
if (mana != null) {
|
||||
player.getManaPool().addMana(mana, game, source);
|
||||
controller.getManaPool().addMana(mana, game, source);
|
||||
result = true;
|
||||
}
|
||||
|
||||
if (!oneChoice) {
|
||||
choice.clearChoice();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -90,7 +90,7 @@ public class AddManaInAnyCombinationEffect extends ManaEffect {
|
|||
sb.append(CardUtil.numberToText(amount.toString()));
|
||||
sb.append(" mana in any combination of ");
|
||||
if (manaSymbols.size() == 5) {
|
||||
sb.append("of colors");
|
||||
sb.append("colors");
|
||||
} else {
|
||||
int i = 0;
|
||||
for (ColoredManaSymbol coloredManaSymbol: manaSymbols) {
|
||||
|
|
|
|||
|
|
@ -22,8 +22,15 @@ public class AttacksIfAbleAllEffect extends RequirementEffect {
|
|||
private final FilterCreaturePermanent filter;
|
||||
|
||||
public AttacksIfAbleAllEffect(FilterCreaturePermanent filter) {
|
||||
super(Duration.WhileOnBattlefield);
|
||||
staticText = new StringBuilder(filter.getMessage()).append(" attack each turn if able").toString();
|
||||
this(filter, Duration.WhileOnBattlefield);
|
||||
}
|
||||
|
||||
public AttacksIfAbleAllEffect(FilterCreaturePermanent filter, Duration duration) {
|
||||
super(duration);
|
||||
staticText = new StringBuilder(filter.getMessage())
|
||||
.append(" attack ")
|
||||
.append(duration.equals(Duration.EndOfTurn) ? "this":"each")
|
||||
.append(" turn if able").toString();
|
||||
this.filter = filter;
|
||||
}
|
||||
|
||||
|
|
@ -44,12 +51,12 @@ public class AttacksIfAbleAllEffect extends RequirementEffect {
|
|||
|
||||
@Override
|
||||
public boolean mustAttack(Game game) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean mustBlock(Game game) {
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -0,0 +1,83 @@
|
|||
/*
|
||||
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification, are
|
||||
* permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||
* conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||
* of conditions and the following disclaimer in the documentation and/or other materials
|
||||
* provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
* The views and conclusions contained in the software and documentation are those of the
|
||||
* authors and should not be interpreted as representing official policies, either expressed
|
||||
* or implied, of BetaSteward_at_googlemail.com.
|
||||
*/
|
||||
package mage.abilities.effects.common.combat;
|
||||
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.effects.RequirementEffect;
|
||||
import mage.constants.Duration;
|
||||
import mage.filter.common.FilterCreaturePermanent;
|
||||
import mage.game.Game;
|
||||
import mage.game.permanent.Permanent;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author LevelX2
|
||||
*/
|
||||
|
||||
public class BlocksIfAbleAllEffect extends RequirementEffect {
|
||||
|
||||
private final FilterCreaturePermanent filter;
|
||||
|
||||
public BlocksIfAbleAllEffect(FilterCreaturePermanent filter) {
|
||||
this(filter,Duration.WhileOnBattlefield);
|
||||
}
|
||||
|
||||
public BlocksIfAbleAllEffect(FilterCreaturePermanent filter, Duration duration) {
|
||||
super(Duration.WhileOnBattlefield);
|
||||
staticText = new StringBuilder(filter.getMessage())
|
||||
.append(" block ")
|
||||
.append(duration.equals(Duration.EndOfTurn) ? "this":"each")
|
||||
.append(" turn if able").toString();
|
||||
this.filter = filter;
|
||||
}
|
||||
public BlocksIfAbleAllEffect(final BlocksIfAbleAllEffect effect) {
|
||||
super(effect);
|
||||
this.filter = effect.filter;
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlocksIfAbleAllEffect copy() {
|
||||
return new BlocksIfAbleAllEffect(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean applies(Permanent permanent, Ability source, Game game) {
|
||||
return filter.match(permanent, source.getSourceId(), source.getControllerId(), game);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean mustAttack(Game game) {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean mustBlock(Game game) {
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -27,13 +27,16 @@
|
|||
*/
|
||||
package mage.abilities.mana;
|
||||
|
||||
import java.util.List;
|
||||
import mage.Mana;
|
||||
import mage.abilities.costs.Cost;
|
||||
import mage.abilities.costs.common.TapSourceCost;
|
||||
import mage.abilities.dynamicvalue.DynamicValue;
|
||||
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||
import mage.abilities.effects.common.AddConditionalManaOfAnyColorEffect;
|
||||
import mage.abilities.mana.builder.ConditionalManaBuilder;
|
||||
import mage.choices.ChoiceColor;
|
||||
import mage.constants.Zone;
|
||||
import mage.game.Game;
|
||||
|
||||
/**
|
||||
* For cards like:
|
||||
|
|
@ -43,6 +46,8 @@ import mage.constants.Zone;
|
|||
*/
|
||||
public class ConditionalAnyColorManaAbility extends ManaAbility {
|
||||
|
||||
private DynamicValue amount;
|
||||
|
||||
public ConditionalAnyColorManaAbility(int amount, ConditionalManaBuilder manaBuilder) {
|
||||
this(new TapSourceCost(), amount, manaBuilder);
|
||||
}
|
||||
|
|
@ -52,22 +57,24 @@ public class ConditionalAnyColorManaAbility extends ManaAbility {
|
|||
}
|
||||
|
||||
public ConditionalAnyColorManaAbility(Cost cost, int amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
|
||||
super(Zone.BATTLEFIELD, new AddConditionalManaOfAnyColorEffect(oneChoice ? 1 :amount, manaBuilder), cost);
|
||||
int choices = amount;
|
||||
if (oneChoice) {
|
||||
for (int i = 1; i < amount; i++) {
|
||||
this.addEffect(new AddConditionalManaOfAnyColorEffect(1 , manaBuilder));
|
||||
}
|
||||
choices = 1;
|
||||
}
|
||||
for (int i = 0; i < choices; i++) {
|
||||
this.addChoice(new ChoiceColor());
|
||||
}
|
||||
this.netMana.add(new Mana(0,0,0,0,0,0,amount));
|
||||
this(cost, new StaticValue(amount), manaBuilder, oneChoice);
|
||||
}
|
||||
|
||||
public ConditionalAnyColorManaAbility(Cost cost, DynamicValue amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
|
||||
super(Zone.BATTLEFIELD, new AddConditionalManaOfAnyColorEffect(amount, manaBuilder, oneChoice), cost);
|
||||
this.amount = amount;
|
||||
}
|
||||
|
||||
public ConditionalAnyColorManaAbility(final ConditionalAnyColorManaAbility ability) {
|
||||
super(ability);
|
||||
this.amount = ability.amount;
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<Mana> getNetMana(Game game) {
|
||||
this.netMana.clear();
|
||||
this.netMana.add(new Mana(0,0,0,0,0,0, amount.calculate(game, this, null)));
|
||||
return super.getNetMana(game);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue