diff --git a/Mage/src/mage/abilities/dynamicvalue/common/OpponentsLostLifeCount.java b/Mage/src/mage/abilities/dynamicvalue/common/OpponentsLostLifeCount.java new file mode 100644 index 00000000000..c32c6a1d9db --- /dev/null +++ b/Mage/src/mage/abilities/dynamicvalue/common/OpponentsLostLifeCount.java @@ -0,0 +1,77 @@ +/* + * 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.abilities.dynamicvalue.common; + +import java.util.UUID; +import mage.abilities.Ability; +import mage.abilities.dynamicvalue.DynamicValue; +import mage.game.Game; +import mage.players.Player; +import mage.watchers.common.PlayerLostLifeWatcher; + +/** + * + * @author LevelX2 + */ + +public class OpponentsLostLifeCount implements DynamicValue { + + @Override + public int calculate(Game game, Ability sourceAbility) { + return this.calculate(game, sourceAbility.getControllerId()); + } + + public int calculate(Game game, UUID controllerId) { + PlayerLostLifeWatcher watcher = (PlayerLostLifeWatcher) game.getState().getWatchers().get("PlayerLostLifeWatcher"); + Player you = game.getPlayer(controllerId); + if (watcher != null && you != null) { + int amountLifeLost = 0; + for(UUID opponent: you.getInRange()) { + amountLifeLost += watcher.getLiveLost(opponent); + } + return amountLifeLost; + } + return 0; + } + + @Override + public DynamicValue clone() { + return new OpponentsLostLifeCount(); + } + + @Override + public String toString() { + return "X"; + } + + @Override + public String getMessage() { + return "the total life lost by your opponents this turn"; + } +} \ No newline at end of file diff --git a/Mage/src/mage/game/GameImpl.java b/Mage/src/mage/game/GameImpl.java index ad35206460b..f18c422cf9a 100644 --- a/Mage/src/mage/game/GameImpl.java +++ b/Mage/src/mage/game/GameImpl.java @@ -580,6 +580,7 @@ public abstract class GameImpl> implements Game, Serializa state.getWatchers().add(new CastSpellLastTurnWatcher()); state.getWatchers().add(new MiracleWatcher()); state.getWatchers().add(new SoulbondWatcher()); + state.getWatchers().add(new PlayerLostLifeWatcher()); //20100716 - 103.5 for (UUID playerId: state.getPlayerList(startingPlayerId)) { diff --git a/Mage/src/mage/watchers/common/PlayerLostLifeWatcher.java b/Mage/src/mage/watchers/common/PlayerLostLifeWatcher.java new file mode 100644 index 00000000000..c4f69955398 --- /dev/null +++ b/Mage/src/mage/watchers/common/PlayerLostLifeWatcher.java @@ -0,0 +1,99 @@ +/* + * 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.watchers.common; + +import java.util.HashMap; +import java.util.Map; +import java.util.Map.Entry; +import java.util.UUID; +import mage.Constants.WatcherScope; +import mage.game.Game; +import mage.game.events.GameEvent; +import mage.watchers.WatcherImpl; + + + +/** + * Counts amount of life lost current turn by players. + * + * + * @author LevelX2 + */ +public class PlayerLostLifeWatcher extends WatcherImpl { + + private Map amountOfLifeLostThisTurn = new HashMap(); + + public PlayerLostLifeWatcher() { + super("PlayerLostLifeWatcher", WatcherScope.GAME); + } + + public PlayerLostLifeWatcher(final PlayerLostLifeWatcher watcher) { + super(watcher); + for (Entry entry : watcher.amountOfLifeLostThisTurn.entrySet()) { + amountOfLifeLostThisTurn.put(entry.getKey(), entry.getValue()); + } + } + + @Override + public void watch(GameEvent event, Game game) { + if (event.getType() == GameEvent.EventType.UNTAP_STEP_PRE) { + reset(); + } + if (event.getType() == GameEvent.EventType.LOST_LIFE) { + UUID playerId = event.getPlayerId(); + if (playerId != null) { + Integer amount = amountOfLifeLostThisTurn.get(playerId); + if (amount == null) { + amount = Integer.valueOf(event.getAmount()); + } else { + amount = Integer.valueOf(amount + event.getAmount()); + } + amountOfLifeLostThisTurn.put(playerId, amount); + } + } + } + + public int getLiveLost(UUID playerId) { + Integer amount = amountOfLifeLostThisTurn.get(playerId); + if (amount != null) { + return amount.intValue(); + } + return 0; + } + + @Override + public void reset() { + amountOfLifeLostThisTurn.clear(); + } + + @Override + public PlayerLostLifeWatcher copy() { + return new PlayerLostLifeWatcher(this); + } +}