[ONE] Implement Bloated Contaminator

This commit is contained in:
theelk801 2023-01-14 12:12:24 -05:00
parent c1d425ba09
commit 4acd7d6604
5 changed files with 95 additions and 0 deletions

View file

@ -0,0 +1,40 @@
package mage.abilities.keyword;
import mage.abilities.MageSingleton;
import mage.abilities.StaticAbility;
import mage.abilities.icon.abilities.InfectAbilityIcon;
import mage.constants.Zone;
import java.io.ObjectStreamException;
/**
* @author TheElk801
*/
public class ToxicAbility extends StaticAbility {
private final int amount;
public ToxicAbility(int amount) {
super(Zone.BATTLEFIELD, null);
this.amount = amount;
}
private ToxicAbility(final ToxicAbility ability) {
super(ability);
this.amount = ability.amount;
}
@Override
public String getRule() {
return "toxic " + amount + " <i>(Players dealt combat damage by this creature also get a poison counter.)</i>";
}
@Override
public ToxicAbility copy() {
return new ToxicAbility(this);
}
public int getAmount() {
return amount;
}
}

View file

@ -2178,6 +2178,13 @@ public abstract class PlayerImpl implements Player, Serializable {
player.gainLife(actualDamage, game, source);
}
}
if (combatDamage && sourceAbilities != null && sourceAbilities.containsClass(ToxicAbility.class)) {
int counters = CardUtil
.castStream(sourceAbilities.stream(), ToxicAbility.class)
.mapToInt(ToxicAbility::getAmount)
.sum();
addCounters(CounterType.POISON.createInstance(counters), sourceControllerId, source, game);
}
// Unstable ability - Earl of Squirrel
if (sourceAbilities != null && sourceAbilities.containsKey(SquirrellinkAbility.getInstance().getId())) {
Player player = game.getPlayer(sourceControllerId);