forked from External/mage
1a. Make `costs`, `manaCosts`, and `manaCostsToPay` private in `AbilityImpl` with access through getters/setters 1b. fix cost adjuster for imprinted cards affected by the above 2a. Lazy instantiation for rarely used `data` field in `TargetPointerImpl` 3a. Pre-allocate certain array sizes in `Modes` and `CostsImpl` 4a. Make `manaTemplate` private in `BasicManaEffect`, copy when passing outside the class 4b. Don't copy `manaTemplate` in copy constructor since it doesn't change 4c. Add comments explaining copy usage for `manaTemplate` 4d. Remove redundant variable assignment and make fields final --------- Co-authored-by: xenohedron <xenohedron@users.noreply.github.com>
36 lines
1.1 KiB
Java
36 lines
1.1 KiB
Java
|
|
|
|
package mage.abilities.keyword;
|
|
|
|
import mage.abilities.ActivatedAbilityImpl;
|
|
import mage.abilities.costs.mana.ManaCosts;
|
|
import mage.abilities.effects.common.counter.AddCountersSourceEffect;
|
|
import mage.constants.TimingRule;
|
|
import mage.constants.Zone;
|
|
import mage.counters.CounterType;
|
|
|
|
/**
|
|
* @author BetaSteward_at_googlemail.com
|
|
*/
|
|
public class LevelUpAbility extends ActivatedAbilityImpl {
|
|
|
|
public LevelUpAbility(ManaCosts costs) {
|
|
super(Zone.BATTLEFIELD, new AddCountersSourceEffect(CounterType.LEVEL.createInstance()), costs);
|
|
this.timing = TimingRule.SORCERY;
|
|
}
|
|
|
|
protected LevelUpAbility(final LevelUpAbility ability) {
|
|
super(ability);
|
|
}
|
|
|
|
@Override
|
|
public LevelUpAbility copy() {
|
|
return new LevelUpAbility(this);
|
|
}
|
|
|
|
@Override
|
|
public String getRule() {
|
|
return new StringBuilder("Level up ").append(getManaCostsToPay().getText())
|
|
.append(" <i>(").append(getManaCostsToPay().getText()).append(": Put a level counter on this. Level up only as a sorcery.)</i>").toString();
|
|
}
|
|
}
|