mirror of
https://github.com/correl/mage.git
synced 2025-01-12 03:00:13 +00:00
commit
890b7fd703
5 changed files with 23 additions and 7 deletions
|
@ -68,7 +68,7 @@ class AcidicSoilEffect extends OneShotEffect {
|
||||||
|
|
||||||
AcidicSoilEffect() {
|
AcidicSoilEffect() {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
staticText = "Acidic Soil deals damage to each player equal to the number of lands he or she controls";
|
staticText = "{this} deals damage to each player equal to the number of lands he or she controls";
|
||||||
}
|
}
|
||||||
|
|
||||||
AcidicSoilEffect(final AcidicSoilEffect effect) {
|
AcidicSoilEffect(final AcidicSoilEffect effect) {
|
||||||
|
|
|
@ -99,7 +99,13 @@ class HubrisReturnEffect extends OneShotEffect {
|
||||||
for (UUID targetId : targetPointer.getTargets(game, source)) {
|
for (UUID targetId : targetPointer.getTargets(game, source)) {
|
||||||
Permanent creature = game.getPermanent(targetId);
|
Permanent creature = game.getPermanent(targetId);
|
||||||
if (creature != null) {
|
if (creature != null) {
|
||||||
Cards cardsToHand = new CardsImpl(creature.getAttachments());
|
Cards cardsToHand = new CardsImpl();
|
||||||
|
for (UUID cardId : creature.getAttachments()) {
|
||||||
|
Permanent card = game.getPermanent(cardId);
|
||||||
|
if (card != null && card.hasSubtype(SubType.AURA, game)) {
|
||||||
|
cardsToHand.add(card);
|
||||||
|
}
|
||||||
|
}
|
||||||
cardsToHand.add(creature);
|
cardsToHand.add(creature);
|
||||||
controller.moveCards(cardsToHand, Zone.HAND, source, game);
|
controller.moveCards(cardsToHand, Zone.HAND, source, game);
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,8 +48,10 @@ import mage.constants.Outcome;
|
||||||
import mage.constants.Duration;
|
import mage.constants.Duration;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.counters.BoostCounter;
|
import mage.counters.BoostCounter;
|
||||||
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.filter.predicate.Predicates;
|
import mage.filter.predicate.Predicates;
|
||||||
|
import mage.filter.predicate.mageobject.SubtypePredicate;
|
||||||
import mage.filter.predicate.permanent.TappedPredicate;
|
import mage.filter.predicate.permanent.TappedPredicate;
|
||||||
import mage.target.TargetPermanent;
|
import mage.target.TargetPermanent;
|
||||||
import mage.target.common.TargetControlledCreaturePermanent;
|
import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
|
@ -60,6 +62,12 @@ import mage.target.common.TargetCreatureOrPlayer;
|
||||||
* @author L_J
|
* @author L_J
|
||||||
*/
|
*/
|
||||||
public class KrovikanPlague extends CardImpl {
|
public class KrovikanPlague extends CardImpl {
|
||||||
|
|
||||||
|
private static final FilterControlledCreaturePermanent filterNonWall = new FilterControlledCreaturePermanent("non-Wall creature you control");
|
||||||
|
|
||||||
|
static {
|
||||||
|
filterNonWall.add(Predicates.not(new SubtypePredicate(SubType.WALL)));
|
||||||
|
}
|
||||||
|
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("enchanted creature is untapped");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("enchanted creature is untapped");
|
||||||
|
|
||||||
|
@ -71,8 +79,8 @@ public class KrovikanPlague extends CardImpl {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{B}");
|
||||||
this.subtype.add(SubType.AURA);
|
this.subtype.add(SubType.AURA);
|
||||||
|
|
||||||
// Enchant creature you control
|
// Enchant non-Wall creature you control
|
||||||
TargetPermanent auraTarget = new TargetControlledCreaturePermanent();
|
TargetPermanent auraTarget = new TargetControlledCreaturePermanent(filterNonWall);
|
||||||
this.getSpellAbility().addTarget(auraTarget);
|
this.getSpellAbility().addTarget(auraTarget);
|
||||||
this.getSpellAbility().addEffect(new AttachEffect(Outcome.BoostCreature));
|
this.getSpellAbility().addEffect(new AttachEffect(Outcome.BoostCreature));
|
||||||
Ability ability = new EnchantAbility(auraTarget.getTargetName());
|
Ability ability = new EnchantAbility(auraTarget.getTargetName());
|
||||||
|
|
|
@ -59,7 +59,7 @@ public class AtTheBeginOfNextEndStepDelayedTriggeredAbility extends DelayedTrigg
|
||||||
}
|
}
|
||||||
|
|
||||||
public AtTheBeginOfNextEndStepDelayedTriggeredAbility(Zone zone, Effect effect, TargetController targetController, Condition condition) {
|
public AtTheBeginOfNextEndStepDelayedTriggeredAbility(Zone zone, Effect effect, TargetController targetController, Condition condition) {
|
||||||
super(effect, Duration.EndOfTurn);
|
super(effect, Duration.Custom);
|
||||||
this.zone = zone;
|
this.zone = zone;
|
||||||
this.targetController = targetController;
|
this.targetController = targetController;
|
||||||
this.condition = condition;
|
this.condition = condition;
|
||||||
|
|
|
@ -73,8 +73,10 @@ public class BecomesColorOrColorsTargetEffect extends OneShotEffect {
|
||||||
|
|
||||||
if (controller != null && target != null) {
|
if (controller != null && target != null) {
|
||||||
for (int i = 0; i < 5; i++) {
|
for (int i = 0; i < 5; i++) {
|
||||||
if (!controller.chooseUse(Outcome.Neutral, "Do you wish to choose another color?", source, game)) {
|
if (i > 0) {
|
||||||
break;
|
if (!controller.chooseUse(Outcome.Neutral, "Do you wish to choose another color?", source, game)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
ChoiceColor choiceColor = new ChoiceColor();
|
ChoiceColor choiceColor = new ChoiceColor();
|
||||||
controller.choose(Outcome.Benefit, choiceColor, game);
|
controller.choose(Outcome.Benefit, choiceColor, game);
|
||||||
|
|
Loading…
Reference in a new issue