[FRF] Added Brutal Hordechief and Crucible of the Spirit Dragon. FRF Complete!!!

This commit is contained in:
LevelX2 2015-01-17 13:08:39 +01:00
parent 1d584afb4f
commit de10554ec4
9 changed files with 451 additions and 36 deletions

View file

@ -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();
}
}

View file

@ -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) {

View file

@ -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;
}
}

View file

@ -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;
}
}

View file

@ -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