fixed issue 19 (again) + added some new sample decks

This commit is contained in:
BetaSteward 2010-11-29 04:27:11 +00:00
parent 0211787433
commit d6dd2a22cc
10 changed files with 214 additions and 111 deletions

View file

@ -34,16 +34,13 @@ import mage.Constants.Outcome;
import mage.Constants.Rarity;
import mage.Constants.Zone;
import mage.MageInt;
import mage.abilities.common.EntersBattlefieldTriggeredAbility;
import mage.abilities.common.ZoneChangeTriggeredAbility;
import mage.abilities.effects.common.SearchLibraryPutInPlayEffect;
import mage.abilities.keyword.FirstStrikeAbility;
import mage.cards.CardImpl;
import mage.filter.FilterCard;
import mage.filter.common.FilterLandPermanent;
import mage.game.Game;
import mage.game.events.GameEvent;
import mage.game.events.GameEvent.EventType;
import mage.game.events.ZoneChangeEvent;
import mage.target.common.TargetCardInLibrary;
/**
@ -81,13 +78,18 @@ public class KnightOfTheWhiteOrchid extends CardImpl<KnightOfTheWhiteOrchid> {
}
class KnightOfTheWhiteOrchidAbility extends EntersBattlefieldTriggeredAbility<KnightOfTheWhiteOrchidAbility> {
class KnightOfTheWhiteOrchidAbility extends ZoneChangeTriggeredAbility<KnightOfTheWhiteOrchidAbility> {
private static FilterCard filter1 = new FilterCard("Plains");
private static FilterLandPermanent filter2 = new FilterLandPermanent();
static {
filter1.getName().add("Plains");
}
public KnightOfTheWhiteOrchidAbility() {
super(null, true);
FilterCard filter = new FilterCard("Plains");
filter.getName().add("Plains");
TargetCardInLibrary target = new TargetCardInLibrary(filter);
super(Zone.BATTLEFIELD, null, "When {this} enters the battlefield, if an opponent controls more lands than you, you may ", true);
TargetCardInLibrary target = new TargetCardInLibrary(filter1);
addEffect(new SearchLibraryPutInPlayEffect(target, false, Outcome.PutLandInPlay));
}
@ -100,34 +102,15 @@ class KnightOfTheWhiteOrchidAbility extends EntersBattlefieldTriggeredAbility<Kn
return new KnightOfTheWhiteOrchidAbility(this);
}
@Override
public boolean checkTrigger(GameEvent event, Game game) {
if (event.getType() == EventType.ZONE_CHANGE && event.getTargetId().equals(this.getSourceId()) ) {
ZoneChangeEvent zEvent = (ZoneChangeEvent)event;
if (zEvent.getToZone() == Zone.BATTLEFIELD) {
trigger(game, this.controllerId);
return true;
}
}
return false;
}
@Override
public boolean checkInterveningIfClause(Game game) {
FilterLandPermanent filter = new FilterLandPermanent();
int numLands = game.getBattlefield().countAll(filter, this.controllerId);
int numLands = game.getBattlefield().countAll(filter2, this.controllerId);
for (UUID opponentId: game.getOpponents(this.controllerId)) {
if (numLands < game.getBattlefield().countAll(filter, opponentId)) {
if (numLands < game.getBattlefield().countAll(filter2, opponentId)) {
return true;
}
}
return false;
}
@Override
public String getRule() {
return "When {this} enters the battlefield, if an opponent controls more lands than you, you may " + super.getRule();
}
}

View file

@ -0,0 +1,69 @@
/*
* 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.zendikar;
import java.util.UUID;
import mage.Constants.CardType;
import mage.Constants.Rarity;
import mage.abilities.common.EntersBattlefieldTappedAbility;
import mage.abilities.common.EntersBattlefieldTriggeredAbility;
import mage.abilities.effects.common.GainLifeEffect;
import mage.abilities.mana.BlueManaAbility;
import mage.abilities.mana.WhiteManaAbility;
import mage.cards.CardImpl;
/**
*
* @author BetaSteward_at_googlemail.com
*/
public class SejiriRefuge extends CardImpl<SejiriRefuge> {
public SejiriRefuge(UUID ownerId) {
super(ownerId, 224, "Sejiri Refuge", Rarity.UNCOMMON, new CardType[]{CardType.LAND}, null);
this.expansionSetCode = "ZEN";
this.addAbility(new EntersBattlefieldTappedAbility());
this.addAbility(new EntersBattlefieldTriggeredAbility(new GainLifeEffect(1), false));
this.addAbility(new WhiteManaAbility());
this.addAbility(new BlueManaAbility());
}
public SejiriRefuge(final SejiriRefuge card) {
super(card);
}
@Override
public SejiriRefuge copy() {
return new SejiriRefuge(this);
}
@Override
public String getArt() {
return "126610_typ_reg_sty_010.jpg";
}
}