forked from External/mage
[LTR] Implement Barrow-Blade (#10539)
* [LTR] Implement Barrow-Blade * Took ideas from Wooden Stake, Humble and Shadowspear * Play tested effects * Simpler constructor for equip * Revamped BlocksOrBlockedAttachedTriggeredAbility * New logic in `BlocksOrBlockedAttachedTriggeredAbility` * Changed `Ferocity` and `Gift Of The Woods` * Removed custom class from `Barrow Blade` * New class, revert changes in cards * Added the new class `BlocksOrBlockedByCreatureAttachedTriggeredAbility()` * Reverted changes to `BlocksOrBlockedAttachedTriggeredAbility()` but including `AttachmentType` in constructor * Reverted changes to `Ferocity` and `GiftOfTheWoods` * Changed `Barrow-Blade` to use `BlocksOrBlockedByCreatureAttachedTriggeredAbility()` * Added a few comments * Tried optimizing the IF statements in the new class but whenever I tried some condition would stop working, accepting suggestions * Null check added * Added a null check for game.getPermanent(sourceId) * Changed checks to the top to avoid unnecessary processing when encountering any null variable * Removed unnecessary import
This commit is contained in:
parent
1f0189a098
commit
6a20840f4e
6 changed files with 156 additions and 6 deletions
47
Mage.Sets/src/mage/cards/b/BarrowBlade.java
Normal file
47
Mage.Sets/src/mage/cards/b/BarrowBlade.java
Normal file
|
|
@ -0,0 +1,47 @@
|
|||
package mage.cards.b;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import mage.abilities.common.BlocksOrBlockedAttachedTriggeredAbility;
|
||||
import mage.abilities.common.BlocksOrBlockedByCreatureAttachedTriggeredAbility;
|
||||
import mage.abilities.common.SimpleStaticAbility;
|
||||
import mage.abilities.effects.common.continuous.BoostEquippedEffect;
|
||||
import mage.abilities.effects.common.continuous.LoseAllAbilitiesTargetEffect;
|
||||
import mage.abilities.keyword.EquipAbility;
|
||||
import mage.constants.*;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
|
||||
/**
|
||||
* @author TiagoMDG
|
||||
*/
|
||||
public final class BarrowBlade extends CardImpl {
|
||||
|
||||
public BarrowBlade(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{1}");
|
||||
|
||||
this.subtype.add(SubType.EQUIPMENT);
|
||||
|
||||
// Equipped creature gets +1/+1.
|
||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new BoostEquippedEffect(1, 1)));
|
||||
|
||||
// Whenever equipped creature blocks or becomes blocked by a creature, that creature loses all abilities until end of turn.
|
||||
this.addAbility(new BlocksOrBlockedByCreatureAttachedTriggeredAbility(
|
||||
new LoseAllAbilitiesTargetEffect(Duration.EndOfTurn)
|
||||
.setText("that creature loses all abilities " +
|
||||
"until end of turn."), AttachmentType.EQUIPMENT, false));
|
||||
|
||||
|
||||
// Equip {1}
|
||||
this.addAbility(new EquipAbility(1, true));
|
||||
}
|
||||
|
||||
private BarrowBlade(final BarrowBlade card) {
|
||||
super(card);
|
||||
}
|
||||
|
||||
@Override
|
||||
public BarrowBlade copy() {
|
||||
return new BarrowBlade(this);
|
||||
}
|
||||
}
|
||||
|
|
@ -1,12 +1,14 @@
|
|||
package mage.cards.f;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import mage.abilities.common.BlocksOrBlockedAttachedTriggeredAbility;
|
||||
import mage.abilities.effects.common.AttachEffect;
|
||||
import mage.abilities.effects.common.counter.AddCountersTargetEffect;
|
||||
import mage.abilities.keyword.EnchantAbility;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.AttachmentType;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.SubType;
|
||||
|
|
@ -15,7 +17,6 @@ import mage.target.TargetPermanent;
|
|||
import mage.target.common.TargetCreaturePermanent;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author awjackson
|
||||
*/
|
||||
public final class Ferocity extends CardImpl {
|
||||
|
|
@ -34,6 +35,7 @@ public final class Ferocity extends CardImpl {
|
|||
// Whenever enchanted creature blocks or becomes blocked, you may put a +1/+1 counter on it.
|
||||
this.addAbility(new BlocksOrBlockedAttachedTriggeredAbility(
|
||||
new AddCountersTargetEffect(CounterType.P1P1.createInstance()).setText("put a +1/+1 counter on it"),
|
||||
AttachmentType.AURA,
|
||||
true
|
||||
));
|
||||
}
|
||||
|
|
|
|||
|
|
@ -8,6 +8,7 @@ import mage.abilities.effects.common.continuous.BoostTargetEffect;
|
|||
import mage.abilities.keyword.EnchantAbility;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.AttachmentType;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.SubType;
|
||||
|
|
@ -33,7 +34,9 @@ public final class GiftOfTheWoods extends CardImpl {
|
|||
this.addAbility(new EnchantAbility(auraTarget));
|
||||
|
||||
// Whenever enchanted creature blocks or becomes blocked, it gets +0/+3 until end of turn and you gain 1 life.
|
||||
Ability ability = new BlocksOrBlockedAttachedTriggeredAbility(new BoostTargetEffect(0, 3).setText("it gets +0/+3 until end of turn"));
|
||||
Ability ability = new BlocksOrBlockedAttachedTriggeredAbility(new BoostTargetEffect(0, 3)
|
||||
.setText("it gets +0/+3 until end of turn"), AttachmentType.AURA);
|
||||
|
||||
ability.addEffect(new GainLifeEffect(1).concatBy("and"));
|
||||
this.addAbility(ability);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -29,6 +29,7 @@ public final class TheLordOfTheRingsTalesOfMiddleEarth extends ExpansionSet {
|
|||
cards.add(new SetCardInfo("Bag End Porter", 153, Rarity.COMMON, mage.cards.b.BagEndPorter.class));
|
||||
cards.add(new SetCardInfo("Banish from Edoras", 1, Rarity.COMMON, mage.cards.b.BanishFromEdoras.class));
|
||||
cards.add(new SetCardInfo("Barad-dur", 253, Rarity.RARE, mage.cards.b.BaradDur.class));
|
||||
cards.add(new SetCardInfo("Barrow-Blade", 237, Rarity.UNCOMMON, mage.cards.b.BarrowBlade.class));
|
||||
cards.add(new SetCardInfo("Battle-Scarred Goblin", 115, Rarity.COMMON, mage.cards.b.BattleScarredGoblin.class));
|
||||
cards.add(new SetCardInfo("Bilbo's Ring", 298, Rarity.RARE, mage.cards.b.BilbosRing.class));
|
||||
cards.add(new SetCardInfo("Bilbo, Retired Burglar", 196, Rarity.UNCOMMON, mage.cards.b.BilboRetiredBurglar.class));
|
||||
|
|
|
|||
|
|
@ -2,6 +2,7 @@ package mage.abilities.common;
|
|||
|
||||
import mage.abilities.TriggeredAbilityImpl;
|
||||
import mage.abilities.effects.Effect;
|
||||
import mage.constants.AttachmentType;
|
||||
import mage.constants.Zone;
|
||||
import mage.game.Game;
|
||||
import mage.game.events.GameEvent;
|
||||
|
|
@ -13,16 +14,22 @@ import mage.target.targetpointer.FixedTarget;
|
|||
*/
|
||||
public class BlocksOrBlockedAttachedTriggeredAbility extends TriggeredAbilityImpl {
|
||||
|
||||
public BlocksOrBlockedAttachedTriggeredAbility(Effect effect) {
|
||||
this(effect, false);
|
||||
// Type of attachment: AURA or EQUIPMENT
|
||||
private final AttachmentType attachmentType;
|
||||
|
||||
public BlocksOrBlockedAttachedTriggeredAbility(Effect effect, AttachmentType attachmentType) {
|
||||
this(effect, attachmentType, false);
|
||||
}
|
||||
public BlocksOrBlockedAttachedTriggeredAbility(Effect effect, boolean optional) {
|
||||
|
||||
public BlocksOrBlockedAttachedTriggeredAbility(Effect effect, AttachmentType attachmentType, boolean optional) {
|
||||
super(Zone.BATTLEFIELD, effect, optional);
|
||||
setTriggerPhrase("Whenever enchanted creature blocks or becomes blocked, ");
|
||||
setTriggerPhrase("Whenever " + attachmentType.verb().toLowerCase() + " creature blocks or becomes blocked, ");
|
||||
this.attachmentType = attachmentType;
|
||||
}
|
||||
|
||||
public BlocksOrBlockedAttachedTriggeredAbility(final BlocksOrBlockedAttachedTriggeredAbility ability) {
|
||||
super(ability);
|
||||
this.attachmentType = ability.attachmentType;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
|||
|
|
@ -0,0 +1,90 @@
|
|||
package mage.abilities.common;
|
||||
|
||||
import mage.abilities.TriggeredAbilityImpl;
|
||||
import mage.abilities.effects.Effect;
|
||||
import mage.constants.AttachmentType;
|
||||
import mage.constants.Zone;
|
||||
import mage.game.Game;
|
||||
import mage.game.events.GameEvent;
|
||||
import mage.game.permanent.Permanent;
|
||||
import mage.target.targetpointer.FixedTarget;
|
||||
|
||||
/**
|
||||
* @author TiagoMDG
|
||||
*/
|
||||
public class BlocksOrBlockedByCreatureAttachedTriggeredAbility extends TriggeredAbilityImpl {
|
||||
|
||||
// Type of attachment AURA or EQUIPMENT
|
||||
private final AttachmentType attachmentType;
|
||||
|
||||
// Controls if the effect should target the creature with the attachment or the blocking/blocked creature
|
||||
private final boolean selfTarget;
|
||||
|
||||
public BlocksOrBlockedByCreatureAttachedTriggeredAbility(Effect effect, AttachmentType attachmentType, boolean selfTarget) {
|
||||
this(effect, attachmentType, selfTarget, false);
|
||||
}
|
||||
|
||||
public BlocksOrBlockedByCreatureAttachedTriggeredAbility(Effect effect, AttachmentType attachmentType, boolean selfTarget, boolean optional) {
|
||||
super(Zone.BATTLEFIELD, effect, optional);
|
||||
setTriggerPhrase("Whenever " + attachmentType.verb().toLowerCase() + " creature blocks or becomes blocked, ");
|
||||
this.attachmentType = attachmentType;
|
||||
this.selfTarget = selfTarget;
|
||||
}
|
||||
|
||||
public BlocksOrBlockedByCreatureAttachedTriggeredAbility(final BlocksOrBlockedByCreatureAttachedTriggeredAbility ability) {
|
||||
super(ability);
|
||||
this.attachmentType = ability.attachmentType;
|
||||
this.selfTarget = ability.selfTarget;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean checkEventType(GameEvent event, Game game) {
|
||||
return event.getType() == GameEvent.EventType.BLOCKER_DECLARED;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean checkTrigger(GameEvent event, Game game) {
|
||||
Permanent blockingCreature = game.getPermanent(event.getSourceId());
|
||||
Permanent blockedCreature = game.getPermanent(event.getTargetId());
|
||||
Permanent attachment = game.getPermanent(sourceId);
|
||||
|
||||
if (attachment == null || blockingCreature == null || blockedCreature == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Permanent attachedCreature = game.getPermanent(attachment.getAttachedTo());
|
||||
|
||||
if (attachedCreature == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!selfTarget) {
|
||||
if (blockedCreature.equals(attachedCreature)) {
|
||||
getEffects().setTargetPointer(new FixedTarget(blockingCreature, game));
|
||||
return true;
|
||||
}
|
||||
|
||||
if (blockingCreature.equals(attachedCreature)) {
|
||||
getEffects().setTargetPointer(new FixedTarget(blockedCreature, game));
|
||||
return true;
|
||||
}
|
||||
} else {
|
||||
if (blockedCreature.equals(attachedCreature)) {
|
||||
getEffects().setTargetPointer(new FixedTarget(blockedCreature, game));
|
||||
return true;
|
||||
}
|
||||
|
||||
if (blockingCreature.equals(attachedCreature)) {
|
||||
getEffects().setTargetPointer(new FixedTarget(blockingCreature, game));
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public BlocksOrBlockedByCreatureAttachedTriggeredAbility copy() {
|
||||
return new BlocksOrBlockedByCreatureAttachedTriggeredAbility(this);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue