mirror of
https://github.com/correl/mage.git
synced 2024-12-26 19:16:54 +00:00
* Induced Amnesia - Fixed a bug that the exiled cards were not returned back to hand.
This commit is contained in:
parent
9b873d7aa4
commit
66533c490e
2 changed files with 11 additions and 11 deletions
|
@ -132,7 +132,7 @@ class InducedAmnesiaReturnEffect extends OneShotEffect {
|
|||
Player controller = game.getPlayer(source.getControllerId());
|
||||
Permanent sourcePermanent = game.getPermanentOrLKIBattlefield(source.getSourceId());
|
||||
if (controller != null && sourcePermanent != null) {
|
||||
UUID exileId = CardUtil.getCardExileZoneId(game, source);
|
||||
UUID exileId = CardUtil.getCardExileZoneId(game, source.getSourceId(), true);
|
||||
int numberOfCards = 0;
|
||||
ExileZone exileZone = game.getExile().getExileZone(exileId);
|
||||
if (exileZone != null) {
|
||||
|
|
|
@ -42,9 +42,9 @@ import mage.cards.CardImpl;
|
|||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.AttachmentType;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.SubType;
|
||||
import mage.constants.Duration;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.SubType;
|
||||
import mage.constants.Zone;
|
||||
import mage.game.Game;
|
||||
import mage.game.events.DamagedPlayerEvent;
|
||||
|
@ -62,10 +62,9 @@ import mage.target.common.TargetCreaturePermanent;
|
|||
public class PollenbrightWings extends CardImpl {
|
||||
|
||||
public PollenbrightWings(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{4}{G}{W}");
|
||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{4}{G}{W}");
|
||||
this.subtype.add(SubType.AURA);
|
||||
|
||||
|
||||
// Enchant creature
|
||||
TargetPermanent auraTarget = new TargetCreaturePermanent();
|
||||
this.getSpellAbility().addTarget(auraTarget);
|
||||
|
@ -73,7 +72,8 @@ public class PollenbrightWings extends CardImpl {
|
|||
Ability ability = new EnchantAbility(auraTarget.getTargetName());
|
||||
this.addAbility(ability);
|
||||
// Enchanted creature has flying.
|
||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new GainAbilityAttachedEffect(FlyingAbility.getInstance(), AttachmentType.AURA, Duration.WhileOnBattlefield)));
|
||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD,
|
||||
new GainAbilityAttachedEffect(FlyingAbility.getInstance(), AttachmentType.AURA, Duration.WhileOnBattlefield)));
|
||||
// Whenever enchanted creature deals combat damage to a player, create that many 1/1 green Saproling creature tokens.
|
||||
this.addAbility(new PollenbrightWingsAbility());
|
||||
}
|
||||
|
@ -111,10 +111,10 @@ class PollenbrightWingsAbility extends TriggeredAbilityImpl {
|
|||
|
||||
@Override
|
||||
public boolean checkTrigger(GameEvent event, Game game) {
|
||||
DamagedPlayerEvent damageEvent = (DamagedPlayerEvent)event;
|
||||
Permanent p = game.getPermanent(event.getSourceId());
|
||||
if (damageEvent.isCombatDamage() && p != null && p.getAttachments().contains(this.getSourceId())) {
|
||||
game.getState().setValue(new StringBuilder("Damage_").append(getSourceId().toString()).toString(), new Integer(damageEvent.getAmount()));
|
||||
DamagedPlayerEvent damageEvent = (DamagedPlayerEvent) event;
|
||||
Permanent damageSource = game.getPermanent(event.getSourceId());
|
||||
if (damageEvent.isCombatDamage() && damageSource != null && damageSource.getAttachments().contains(this.getSourceId())) {
|
||||
game.getState().setValue("Damage_" + getSourceId(), damageEvent.getAmount());
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
@ -144,9 +144,9 @@ class PollenbrightWingsEffect extends OneShotEffect {
|
|||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Integer damage = (Integer) game.getState().getValue(new StringBuilder("Damage_").append(source.getSourceId().toString()).toString());
|
||||
Integer damage = (Integer) game.getState().getValue("Damage_" + source.getSourceId());
|
||||
if (damage != null) {
|
||||
return (new CreateTokenEffect(new SaprolingToken(), damage.intValue()).apply(game, source));
|
||||
return (new CreateTokenEffect(new SaprolingToken(), damage).apply(game, source));
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue