forked from External/mage
Reimplement Common Bond
This commit is contained in:
parent
1f9de03bf3
commit
809c02eb8d
1 changed files with 12 additions and 47 deletions
|
|
@ -1,34 +1,32 @@
|
|||
|
||||
package mage.cards.c;
|
||||
|
||||
import java.util.UUID;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.abilities.effects.common.counter.AddCountersTargetEffect;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.counters.CounterType;
|
||||
import mage.filter.common.FilterCreaturePermanent;
|
||||
import mage.game.Game;
|
||||
import mage.game.permanent.Permanent;
|
||||
import mage.target.common.TargetCreaturePermanent;
|
||||
import mage.target.targetpointer.SecondTargetPointer;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author LevelX2
|
||||
* @author xenohedron
|
||||
*/
|
||||
public final class CommonBond extends CardImpl {
|
||||
|
||||
public CommonBond(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{1}{G}{W}");
|
||||
|
||||
// Put a +1/+1 counter on target creature.
|
||||
this.getSpellAbility().addEffect(new AddCountersTargetEffect(CounterType.P1P1.createInstance()));
|
||||
this.getSpellAbility().addTarget(new TargetCreaturePermanent().withChooseHint("1st"));
|
||||
|
||||
// Put a +1/+1 counter on target creature.
|
||||
this.getSpellAbility().addEffect(new AddCountersTargetEffect(CounterType.P1P1.createInstance())
|
||||
.setTargetPointer(new SecondTargetPointer()).concatBy("<br>"));
|
||||
this.getSpellAbility().addTarget(new TargetCreaturePermanent().withChooseHint("2nd"));
|
||||
|
||||
// Put a +1/+1 counter on target creature. Put a +1/+1 counter on target creature.
|
||||
this.getSpellAbility().addEffect(new CommonBondEffect());
|
||||
this.getSpellAbility().addTarget(new TargetCreaturePermanent(new FilterCreaturePermanent("first creature")));
|
||||
this.getSpellAbility().addTarget(new TargetCreaturePermanent(new FilterCreaturePermanent("second creature (can be the same as the first)")));
|
||||
}
|
||||
|
||||
private CommonBond(final CommonBond card) {
|
||||
|
|
@ -40,36 +38,3 @@ public final class CommonBond extends CardImpl {
|
|||
return new CommonBond(this);
|
||||
}
|
||||
}
|
||||
|
||||
class CommonBondEffect extends OneShotEffect {
|
||||
|
||||
public CommonBondEffect() {
|
||||
super(Outcome.BoostCreature);
|
||||
staticText = "Put a +1/+1 counter on target creature. Put a +1/+1 counter on target creature.";
|
||||
}
|
||||
|
||||
public CommonBondEffect(final CommonBondEffect effect) {
|
||||
super(effect);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
int affectedTargets = 0;
|
||||
Permanent permanent = game.getPermanent(source.getTargets().get(0).getFirstTarget());
|
||||
if (permanent != null) {
|
||||
permanent.addCounters(CounterType.P1P1.createInstance(1), source.getControllerId(), source, game);
|
||||
affectedTargets ++;
|
||||
}
|
||||
permanent = game.getPermanent(source.getTargets().get(1).getFirstTarget());
|
||||
if (permanent != null) {
|
||||
permanent.addCounters(CounterType.P1P1.createInstance(1), source.getControllerId(), source, game);
|
||||
affectedTargets ++;
|
||||
}
|
||||
return affectedTargets > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommonBondEffect copy() {
|
||||
return new CommonBondEffect(this);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue