mirror of
https://github.com/correl/mage.git
synced 2025-01-14 03:00:10 +00:00
Fix Unlicensed Hearse (#8985)
Co-authored-by: DeepCrimson <deepcrimson@users.noreplyl.github.com>
This commit is contained in:
parent
c89f22ac52
commit
c1595b0358
1 changed files with 59 additions and 60 deletions
|
@ -19,43 +19,69 @@ import mage.constants.Duration;
|
|||
import mage.constants.SubType;
|
||||
import mage.constants.Zone;
|
||||
import mage.filter.StaticFilters;
|
||||
import mage.game.ExileZone;
|
||||
import mage.game.Game;
|
||||
import mage.target.common.TargetCardInASingleGraveyard;
|
||||
import mage.util.CardUtil;
|
||||
|
||||
import java.util.HashSet;
|
||||
import java.util.Objects;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
enum UnlicensedHearseValue implements DynamicValue {
|
||||
instance;
|
||||
|
||||
@Override
|
||||
public int calculate(Game game, Ability sourceAbility, Effect effect) {
|
||||
ExileZone cardsExiledWithUnlicensedHearse =
|
||||
game.getExile()
|
||||
.getExileZone(
|
||||
CardUtil.getExileZoneId(
|
||||
game,
|
||||
sourceAbility.getSourceId(),
|
||||
game.getState().getZoneChangeCounter(sourceAbility.getSourceId())));
|
||||
if (cardsExiledWithUnlicensedHearse == null) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return cardsExiledWithUnlicensedHearse.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public UnlicensedHearseValue copy() {
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getMessage() {
|
||||
return "cards exiled with it";
|
||||
}
|
||||
}
|
||||
|
||||
public final class UnlicensedHearse extends CardImpl {
|
||||
|
||||
private static final Hint hint = new ValueHint("Cards exiled", UnlicensedHearseValue.instance);
|
||||
|
||||
public UnlicensedHearse(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{2}");
|
||||
super(ownerId, setInfo, new CardType[] {CardType.ARTIFACT}, "{2}");
|
||||
|
||||
this.subtype.add(SubType.VEHICLE);
|
||||
this.power = new MageInt(0);
|
||||
this.toughness = new MageInt(0);
|
||||
|
||||
// {T}: Exile up to two target cards from a single graveyard.
|
||||
Ability ability = new SimpleActivatedAbility(new ExileTargetForSourceEffect(), new TapSourceCost());
|
||||
ability.addTarget(new TargetCardInASingleGraveyard(
|
||||
0, 2, StaticFilters.FILTER_CARD_CARDS
|
||||
));
|
||||
Ability ability =
|
||||
new SimpleActivatedAbility(new ExileTargetForSourceEffect(), new TapSourceCost());
|
||||
ability.addTarget(new TargetCardInASingleGraveyard(0, 2, StaticFilters.FILTER_CARD_CARDS));
|
||||
this.addAbility(ability);
|
||||
|
||||
// Unlicensed Hearse's power and toughness are each equal to the number of cards exiled with it.
|
||||
this.addAbility(new SimpleStaticAbility(
|
||||
this.addAbility(
|
||||
new SimpleStaticAbility(
|
||||
Zone.ALL,
|
||||
new SetPowerToughnessSourceEffect(
|
||||
UnlicensedHearseValue.instance, Duration.Custom
|
||||
)
|
||||
).addHint(hint));
|
||||
new SetPowerToughnessSourceEffect(UnlicensedHearseValue.instance, Duration.Custom))
|
||||
.addHint(hint));
|
||||
|
||||
// Crew 2
|
||||
this.addAbility(new CrewAbility(2));
|
||||
|
@ -70,30 +96,3 @@ public final class UnlicensedHearse extends CardImpl {
|
|||
return new UnlicensedHearse(this);
|
||||
}
|
||||
}
|
||||
|
||||
enum UnlicensedHearseValue implements DynamicValue {
|
||||
instance;
|
||||
|
||||
@Override
|
||||
public int calculate(Game game, Ability sourceAbility, Effect effect) {
|
||||
return Optional.of(game
|
||||
.getExile()
|
||||
.getExileZone(CardUtil.getExileZoneId(
|
||||
game, sourceAbility.getSourceId(),
|
||||
game.getState().getZoneChangeCounter(sourceAbility.getSourceId())
|
||||
)))
|
||||
.filter(Objects::nonNull)
|
||||
.map(HashSet::size)
|
||||
.orElse(0);
|
||||
}
|
||||
|
||||
@Override
|
||||
public UnlicensedHearseValue copy() {
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getMessage() {
|
||||
return "cards exiled with it";
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue