X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/9656502aaa68fb88bfc0664b0d60e8ed25a9acb0..1c62a29cdf79f170e5c8375f5a657cac085000b4:/src/main/java/com/codingame/game/Referee.java?ds=sidebyside diff --git a/src/main/java/com/codingame/game/Referee.java b/src/main/java/com/codingame/game/Referee.java index dfa3324..67d96e0 100644 --- a/src/main/java/com/codingame/game/Referee.java +++ b/src/main/java/com/codingame/game/Referee.java @@ -9,17 +9,13 @@ import com.codingame.gameengine.core.AbstractPlayer.TimeoutException; import com.codingame.gameengine.core.AbstractReferee; import com.codingame.gameengine.core.GameManager; import com.codingame.gameengine.core.MultiplayerGameManager; -import com.codingame.gameengine.module.entities.GraphicEntityModule; -import com.codingame.gameengine.module.entities.Rectangle; -import com.codingame.gameengine.module.entities.Sprite; -import com.codingame.gameengine.module.entities.Text; -import com.codingame.gameengine.module.entities.Curve; +import com.codingame.game.GodModeManager; import com.google.inject.Inject; import com.google.inject.Provider; public class Referee extends AbstractReferee { @Inject private MultiplayerGameManager gameManager; - @Inject private GraphicEntityModule graphicEntityModule; + @Inject private GodModeManager gm; @Inject private View view; @Inject private Model model; @@ -28,13 +24,14 @@ public class Referee extends AbstractReferee { @Override public void init() { + gm.init(); model.init(gameManager.getSeed()); gameManager.getPlayer(0).model = model.p0; gameManager.getPlayer(1).model = model.p1; for (Player p: gameManager.getPlayers()) { p.gameInit(model.roadLength, model.initialStones, - gameManager.getSeed()); + gameManager.getSeed(), gm.getSalt()); } view.init(model); @@ -71,7 +68,7 @@ public class Referee extends AbstractReferee { * least. */ for (Player player : gameManager.getActivePlayers()) { - player.receiveGameTurn(); + player.receiveGameTurn(); gm.transcend(player); switch (player.type) { case Timeout: disqualify(player, "T/O", "timed out!"); @@ -122,6 +119,7 @@ public class Referee extends AbstractReferee { * exhaustion). */ int delta = 0; + gm.update(gameManager.getPlayers()); for (Player player : gameManager.getActivePlayers()) { player.view.throwStones(player.stoneThrow); delta += player.model.getMultiplier() * player.stoneThrow; @@ -172,6 +170,8 @@ public class Referee extends AbstractReferee { boolean noStones = true; int delta = 0; for (Player player : gameManager.getActivePlayers()) { + if (model.haveWinner() && player.getIndex() == model.getLoser()) + continue; player.stoneThrow = player.model.getStones(); player.model.setStones(0); delta += player.stoneThrow * player.model.getMultiplier();