mirror of
https://github.com/magefree/mage.git
synced 2025-12-22 03:22:00 -08:00
Added Confusion in the Ranks.
This commit is contained in:
parent
5776452760
commit
8d28883f7c
3 changed files with 136 additions and 0 deletions
129
Mage.Sets/src/mage/sets/mirrodin/ConfusionInTheRanks.java
Normal file
129
Mage.Sets/src/mage/sets/mirrodin/ConfusionInTheRanks.java
Normal file
|
|
@ -0,0 +1,129 @@
|
||||||
|
/*
|
||||||
|
* 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.sets.mirrodin;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
import mage.MageObjectReference;
|
||||||
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.common.EntersBattlefieldAllTriggeredAbility;
|
||||||
|
import mage.abilities.effects.Effect;
|
||||||
|
import mage.abilities.effects.common.continuous.ExchangeControlTargetEffect;
|
||||||
|
import mage.cards.CardImpl;
|
||||||
|
import mage.constants.CardType;
|
||||||
|
import mage.constants.Duration;
|
||||||
|
import mage.constants.Rarity;
|
||||||
|
import mage.constants.SetTargetPointer;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import mage.filter.FilterPermanent;
|
||||||
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.CardTypePredicate;
|
||||||
|
import mage.filter.predicate.permanent.ControllerIdPredicate;
|
||||||
|
import mage.game.Game;
|
||||||
|
import mage.game.permanent.Permanent;
|
||||||
|
import mage.target.TargetPermanent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author anonymous
|
||||||
|
*/
|
||||||
|
public class ConfusionInTheRanks extends CardImpl {
|
||||||
|
|
||||||
|
private static final FilterPermanent filter = new FilterPermanent("an artifact, creature, or enchantment");
|
||||||
|
|
||||||
|
static {
|
||||||
|
filter.add(Predicates.or(
|
||||||
|
new CardTypePredicate(CardType.ARTIFACT),
|
||||||
|
new CardTypePredicate(CardType.CREATURE),
|
||||||
|
new CardTypePredicate(CardType.ENCHANTMENT)));
|
||||||
|
}
|
||||||
|
private final UUID originalId;
|
||||||
|
private MageObjectReference enteringPermanentMor;
|
||||||
|
|
||||||
|
public ConfusionInTheRanks(UUID ownerId) {
|
||||||
|
super(ownerId, 87, "Confusion in the Ranks", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{3}{R}{R}");
|
||||||
|
this.expansionSetCode = "MRD";
|
||||||
|
|
||||||
|
// Whenever an artifact, creature, or enchantment enters the battlefield, its controller chooses target permanent another player controls that shares a card type with it. Exchange control of those permanents.
|
||||||
|
Ability ability = new EntersBattlefieldAllTriggeredAbility(
|
||||||
|
Zone.BATTLEFIELD,
|
||||||
|
new ExchangeControlTargetEffect(Duration.EndOfGame, "its controller chooses target permanent another player controls that shares a card type with it. Exchange control of those permanents"),
|
||||||
|
filter,
|
||||||
|
false,
|
||||||
|
SetTargetPointer.PERMANENT,
|
||||||
|
null);
|
||||||
|
ability.addTarget(new TargetPermanent());
|
||||||
|
originalId = ability.getOriginalId();
|
||||||
|
this.addAbility(ability);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ConfusionInTheRanks(final ConfusionInTheRanks card) {
|
||||||
|
super(card);
|
||||||
|
this.originalId = card.originalId;
|
||||||
|
this.enteringPermanentMor = card.enteringPermanentMor;
|
||||||
|
}
|
||||||
|
|
||||||
|
@java.lang.Override
|
||||||
|
public void adjustTargets(Ability ability, Game game) {
|
||||||
|
if (ability.getOriginalId().equals(originalId)) {
|
||||||
|
UUID enteringPermanentId = null;
|
||||||
|
for (Effect effect : ability.getEffects()) {
|
||||||
|
enteringPermanentId = effect.getTargetPointer().getFirst(game, ability);
|
||||||
|
}
|
||||||
|
if (enteringPermanentId != null) {
|
||||||
|
Permanent enteringPermanent = game.getPermanent(enteringPermanentId);
|
||||||
|
if (enteringPermanent != null) {
|
||||||
|
enteringPermanentMor = new MageObjectReference(enteringPermanent, game);
|
||||||
|
ability.setControllerId(enteringPermanent.getControllerId());
|
||||||
|
ability.getTargets().clear();
|
||||||
|
FilterPermanent filterTarget = new FilterPermanent();
|
||||||
|
String message = "";
|
||||||
|
filterTarget.add(Predicates.not(new ControllerIdPredicate(enteringPermanent.getControllerId())));
|
||||||
|
Set<CardTypePredicate> cardTypesPredicates = new HashSet<>(1);
|
||||||
|
for (CardType cardTypeEntering : enteringPermanent.getCardType()) {
|
||||||
|
cardTypesPredicates.add(new CardTypePredicate(cardTypeEntering));
|
||||||
|
if (!message.isEmpty()) {
|
||||||
|
message += "or ";
|
||||||
|
}
|
||||||
|
message += cardTypeEntering.toString().toLowerCase() + " ";
|
||||||
|
}
|
||||||
|
filterTarget.add(Predicates.or(cardTypesPredicates));
|
||||||
|
message += "you do not control";
|
||||||
|
filterTarget.setMessage(message);
|
||||||
|
ability.getTargets().add(new TargetPermanent(filterTarget));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@java.lang.Override
|
||||||
|
public ConfusionInTheRanks copy() {
|
||||||
|
return new ConfusionInTheRanks(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -107,6 +107,10 @@ public class ExchangeControlTargetEffect extends ContinuousEffectImpl {
|
||||||
UUID uuid = source.getTargets().get(1).getFirstTarget();
|
UUID uuid = source.getTargets().get(1).getFirstTarget();
|
||||||
permanent2 = game.getPermanent(uuid);
|
permanent2 = game.getPermanent(uuid);
|
||||||
}
|
}
|
||||||
|
else if (permanent2 == null) {
|
||||||
|
UUID uuid = source.getTargets().get(0).getFirstTarget();
|
||||||
|
permanent2 = game.getPermanent(uuid);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (permanent1 != null && permanent2 != null) {
|
if (permanent1 != null && permanent2 != null) {
|
||||||
// exchange works only for two different controllers
|
// exchange works only for two different controllers
|
||||||
|
|
|
||||||
|
|
@ -142,6 +142,9 @@ public abstract class TargetImpl implements Target {
|
||||||
if (targetName.startsWith("another") || targetName.startsWith("a ") || targetName.startsWith("an ")) {
|
if (targetName.startsWith("another") || targetName.startsWith("a ") || targetName.startsWith("an ")) {
|
||||||
return "Select " + targetName + suffix;
|
return "Select " + targetName + suffix;
|
||||||
}
|
}
|
||||||
|
else if (targetName.startsWith("a") || targetName.startsWith("e") || targetName.startsWith("i") || targetName.startsWith("o") || targetName.startsWith("u")) {
|
||||||
|
return "Select an " + targetName + suffix;
|
||||||
|
}
|
||||||
return "Select a " + targetName + suffix;
|
return "Select a " + targetName + suffix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue