mirror of
https://github.com/correl/mage.git
synced 2025-01-12 03:00:13 +00:00
* Cascade - Fixed that the remaining cards were not set to graveyard in a random order.
This commit is contained in:
parent
e35e44941c
commit
abca80e951
2 changed files with 42 additions and 80 deletions
|
@ -92,8 +92,20 @@ public class CascadeAbility extends TriggeredAbilityImpl {
|
||||||
return new CascadeAbility(this);
|
return new CascadeAbility(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// moved to static method because it's called also from class {link} MaelstromNexus
|
}
|
||||||
public static boolean applyCascade(Outcome outcome, Game game, Ability source) {
|
|
||||||
|
class CascadeEffect extends OneShotEffect {
|
||||||
|
|
||||||
|
public CascadeEffect() {
|
||||||
|
super(Outcome.PutCardInPlay);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CascadeEffect(CascadeEffect effect) {
|
||||||
|
super(effect);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
Card card;
|
Card card;
|
||||||
Player player = game.getPlayer(source.getControllerId());
|
Player player = game.getPlayer(source.getControllerId());
|
||||||
if (player == null) {
|
if (player == null) {
|
||||||
|
@ -117,7 +129,7 @@ public class CascadeAbility extends TriggeredAbilityImpl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Mobe the remaining cards to the buttom of the libraray in a random order
|
// Move the remaining cards to the buttom of the library in a random order
|
||||||
Cards cardsFromExile = new CardsImpl();
|
Cards cardsFromExile = new CardsImpl();
|
||||||
Cards cardsToLibrary = new CardsImpl();
|
Cards cardsToLibrary = new CardsImpl();
|
||||||
cardsFromExile.addAll(exile);
|
cardsFromExile.addAll(exile);
|
||||||
|
@ -126,57 +138,9 @@ public class CascadeAbility extends TriggeredAbilityImpl {
|
||||||
cardsFromExile.remove(card.getId());
|
cardsFromExile.remove(card.getId());
|
||||||
cardsToLibrary.add(card);
|
cardsToLibrary.add(card);
|
||||||
}
|
}
|
||||||
player.putCardsOnBottomOfLibrary(cardsToLibrary, game, source, true);
|
player.putCardsOnBottomOfLibrary(cardsToLibrary, game, source, false);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// !!! Changes to the cascade effect here have to be copied to the cascadeEffect of Maelstrom Nexus card eventually.
|
|
||||||
// There is a functional copy of this effect
|
|
||||||
class CascadeEffect extends OneShotEffect {
|
|
||||||
|
|
||||||
public CascadeEffect() {
|
|
||||||
super(Outcome.PutCardInPlay);
|
|
||||||
}
|
|
||||||
|
|
||||||
public CascadeEffect(CascadeEffect effect) {
|
|
||||||
super(effect);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Game game, Ability source) {
|
|
||||||
return CascadeAbility.applyCascade(outcome, game, source);
|
|
||||||
// Card card;
|
|
||||||
// Player player = game.getPlayer(source.getControllerId());
|
|
||||||
// if (player == null) {
|
|
||||||
// return false;
|
|
||||||
// }
|
|
||||||
// ExileZone exile = game.getExile().createZone(source.getSourceId(), player.getName() + " Cascade");
|
|
||||||
// int sourceCost = game.getCard(source.getSourceId()).getManaCost().convertedManaCost();
|
|
||||||
// do {
|
|
||||||
// card = player.getLibrary().getFromTop(game);
|
|
||||||
// if (card == null) {
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
// player.moveCardToExileWithInfo(card, exile.getId(), exile.getName(), source.getSourceId(), game, Zone.LIBRARY);
|
|
||||||
// } while (player.isInGame() && card.getCardType().contains(CardType.LAND) || card.getManaCost().convertedManaCost() >= sourceCost);
|
|
||||||
//
|
|
||||||
// if (card != null) {
|
|
||||||
// if (player.chooseUse(outcome, "Use cascade effect on " + card.getName() + "?", game)) {
|
|
||||||
// if(player.cast(card.getSpellAbility(), game, true)){
|
|
||||||
// exile.remove(card.getId());
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// while (exile.size() > 0) {
|
|
||||||
// card = exile.getRandom(game);
|
|
||||||
// exile.remove(card.getId());
|
|
||||||
// player.moveCardToLibraryWithInfo(card, source.getSourceId(), game, Zone.EXILED, false, false);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CascadeEffect copy() {
|
public CascadeEffect copy() {
|
||||||
|
|
|
@ -48,36 +48,33 @@ import mage.players.Player;
|
||||||
import mage.target.common.TargetCardInYourGraveyard;
|
import mage.target.common.TargetCardInYourGraveyard;
|
||||||
import mage.util.CardUtil;
|
import mage.util.CardUtil;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 702.65. Delve
|
* 702.65. Delve 702.65a Delve is a static ability that functions while the
|
||||||
* 702.65a Delve is a static ability that functions while the spell with delve is on the stack.
|
* spell with delve is on the stack. “Delve” means “For each generic mana in
|
||||||
* “Delve” means “For each generic mana in this spell’s total cost, you may exile a card
|
* this spell’s total cost, you may exile a card from your graveyard rather than
|
||||||
* from your graveyard rather than pay that mana.” The delve ability isn’t an additional
|
* pay that mana.” The delve ability isn’t an additional or alternative cost and
|
||||||
* or alternative cost and applies only after the total cost of the spell with delve is
|
* applies only after the total cost of the spell with delve is determined.
|
||||||
* determined.
|
|
||||||
* 702.65b Multiple instances of delve on the same spell are redundant.
|
* 702.65b Multiple instances of delve on the same spell are redundant.
|
||||||
*
|
*
|
||||||
* * The rules for delve have changed slightly since it was last in an expansion. Previously, delve
|
* * The rules for delve have changed slightly since it was last in an
|
||||||
* reduced the cost to cast a spell. Under the current rules, you exile cards from your graveyard
|
* expansion. Previously, delve reduced the cost to cast a spell. Under the
|
||||||
* at the same time you pay the spell’s cost. Exiling a card this way is simply another way to pay
|
* current rules, you exile cards from your graveyard at the same time you pay
|
||||||
* that cost.
|
* the spell’s cost. Exiling a card this way is simply another way to pay that
|
||||||
* * Delve doesn’t change a spell’s mana cost or converted mana cost. For example, Dead Drop’s converted
|
* cost. * Delve doesn’t change a spell’s mana cost or converted mana cost. For
|
||||||
* mana cost is 10 even if you exiled three cards to cast it.
|
* example, Dead Drop’s converted mana cost is 10 even if you exiled three cards
|
||||||
* * You can’t exile cards to pay for the colored mana requirements of a spell with delve.
|
* to cast it. * You can’t exile cards to pay for the colored mana requirements
|
||||||
* * You can’t exile more cards than the generic mana requirement of a spell with delve. For example,
|
* of a spell with delve. * You can’t exile more cards than the generic mana
|
||||||
* you can’t exile more than nine cards from your graveyard to cast Dead Drop.
|
* requirement of a spell with delve. For example, you can’t exile more than
|
||||||
* * Because delve isn’t an alternative cost, it can be used in conjunction with alternative costs.
|
* nine cards from your graveyard to cast Dead Drop. * Because delve isn’t an
|
||||||
|
* alternative cost, it can be used in conjunction with alternative costs.
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*
|
*
|
||||||
* TODO: Change card exiling to a way to pay mana costs, now it's maybe not passible to pay costs from effects that
|
* TODO: Change card exiling to a way to pay mana costs, now it's maybe not
|
||||||
* increase the mana costs.
|
* passible to pay costs from effects that increase the mana costs.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class DelveAbility extends SimpleStaticAbility implements AlternateManaPaymentAbility {
|
public class DelveAbility extends SimpleStaticAbility implements AlternateManaPaymentAbility {
|
||||||
|
|
||||||
|
|
||||||
public DelveAbility() {
|
public DelveAbility() {
|
||||||
super(Zone.STACK, null);
|
super(Zone.STACK, null);
|
||||||
this.setRuleAtTheTop(true);
|
this.setRuleAtTheTop(true);
|
||||||
|
@ -163,6 +160,7 @@ class DelveEffect extends OneShotEffect {
|
||||||
manaPool.addMana(new Mana(0, 0, 0, 0, 0, exiledCards.size(), 0), game, source);
|
manaPool.addMana(new Mana(0, 0, 0, 0, 0, exiledCards.size(), 0), game, source);
|
||||||
manaPool.unlockManaType(ManaType.COLORLESS);
|
manaPool.unlockManaType(ManaType.COLORLESS);
|
||||||
String keyString = CardUtil.getCardZoneString("delvedCards", source.getSourceId(), game);
|
String keyString = CardUtil.getCardZoneString("delvedCards", source.getSourceId(), game);
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
List<Card> delvedCards = (List<Card>) game.getState().getValue(keyString);
|
List<Card> delvedCards = (List<Card>) game.getState().getValue(keyString);
|
||||||
if (delvedCards == null) {
|
if (delvedCards == null) {
|
||||||
game.getState().setValue(keyString, exiledCards);
|
game.getState().setValue(keyString, exiledCards);
|
||||||
|
|
Loading…
Reference in a new issue