X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/e0da785e68b21f4906f4f0bc849bb7bbab1abeb8..refs/heads/trolls-have-no-master:/src/main/java/com/codingame/game/Referee.java diff --git a/src/main/java/com/codingame/game/Referee.java b/src/main/java/com/codingame/game/Referee.java index b15b4b0..8f5fc97 100644 --- a/src/main/java/com/codingame/game/Referee.java +++ b/src/main/java/com/codingame/game/Referee.java @@ -7,42 +7,40 @@ import java.util.Random; 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 GameManager gameManager; + @Inject private GodModeManager gm; + @Inject private LeagueManager league; @Inject private View view; @Inject private Model model; + boolean disqual = false; + @Override public void init() { - model.init(gameManager.getSeed()); + gm.init(); + model.init(); gameManager.getPlayer(0).model = model.p0; gameManager.getPlayer(1).model = model.p1; for (Player p: gameManager.getPlayers()) { - p.gameInit(model.roadLength, model.initialStones); + p.gameInit(model.roadLength, model.initialStones, + model.seed, gm.getSalt()); } view.init(model); gameManager.getPlayer(0).view = view.p0; gameManager.getPlayer(1).view = view.p1; - gameManager.setFrameDuration(2000); } private void disqualify(Player player, String popup, String message) { player.deactivate(player.getNicknameToken() + " " + popup); - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " " + message)); + player.view.disqualify(message); player.setScore(-1); } @@ -52,6 +50,11 @@ public class Referee extends AbstractReferee { view.startTurn(); + // Did I mention I hate Java? It didn't *have* to be this ugly! + if (disqual) { endGame(); return; } + if (model.exhausted()) { finishStones(); return ;} + if (model.haveWinner()) { endGame(); return; } + for (Player player : gameManager.getActivePlayers()) { player.sendGameTurn(); } @@ -62,9 +65,8 @@ public class Referee extends AbstractReferee { * is ill-formed it could help them debug. Or shame them, at * least. */ - boolean disqual = false; for (Player player : gameManager.getActivePlayers()) { - player.receiveGameTurn(); + player.receiveGameTurn(); gm.transcend(player); switch (player.type) { case Timeout: disqualify(player, "T/O", "timed out!"); @@ -79,7 +81,7 @@ public class Referee extends AbstractReferee { case Throw: try { player.model.consumeStones(player.stoneThrow); } catch (Model.Player.ThrewMoreStonesThanHad e) { - if (model.random.nextInt(10) > 0) { + if (model.FIX_IT()) { player.view.threwMoreStonesThanHad(); player.stoneThrow = player.model.consumeMaxStones(); } @@ -90,7 +92,7 @@ public class Referee extends AbstractReferee { } } catch (Model.Player.FailedToThrowStonesAndShouldHave e) { - if (model.random.nextInt(10) > 0) { + if (model.FIX_IT()) { player.view.failedToThrowStonesAndShouldHave(); player.stoneThrow = player.model.consumeMinStones(); } @@ -103,8 +105,9 @@ public class Referee extends AbstractReferee { } player.view.displayMessage(player.messageString); } + if (disqual) return; - /* Update game model and view. + /* Update game model and view, stones' part. * * As a special case, the "cheater" (sending out negative * stones) handling is deferred here because we need to update @@ -115,16 +118,25 @@ public class Referee extends AbstractReferee { * exhaustion). */ int delta = 0; - boolean victory = false; - boolean exhausted = false; + gm.update(gameManager.getPlayers()); for (Player player : gameManager.getActivePlayers()) { player.view.throwStones(player.stoneThrow); delta += player.model.getMultiplier() * player.stoneThrow; if (player.stoneThrow < 0) { - disqualify(player, "CHEAT", "cheated. Banning account."); - player.view.markCheat(); - disqual = true; + switch(league.cheatLevel) { + case ALLOWED: + break; + case TOLERATED: + player.view.markCheat(); + if (model.random.nextInt(2) == 0) player.model.loseRound(); + break; + case FORBIDDEN: + disqualify(player, "CHEAT", "cheated. Banning account."); + player.view.markCheat(); + disqual = true; + break; + } } if (player.stoneThrow != 0) { player.view.animateStones(player.stoneThrow); @@ -132,7 +144,9 @@ public class Referee extends AbstractReferee { } } - /* If a player cheated, delta is unusable as is. + /* Update game model and view, troll part. + * + * If a player cheated, delta is unusable as is. * (Consider the case the player on the right sent * INT_MIN. INT_MIN * (-1) = INT_MIN, so that player * would both glean the stones *and* push the troll away. @@ -149,35 +163,49 @@ public class Referee extends AbstractReferee { else if (cheat1) delta = 1; if (delta > 0) { - model.trollPosition++; + model.moveTroll(+1); view.moveTroll(View.Dir.RIGHT); } else if (delta < 0) { - model.trollPosition--; + model.moveTroll(-1); view.moveTroll(View.Dir.LEFT); } else { view.moveTroll(View.Dir.STILL); // XXX animate } + } + // XXX very similar to main turn pendant + private void finishStones() { + boolean noStones = true; + int delta = 0; for (Player player : gameManager.getActivePlayers()) { - player.model.adjustScore(model.trollPosition); - } - - if (model.haveWinner()) { - int loser = model.getLoser(); - gameManager.getPlayer(loser).view.destroy(); - victory = true; + if (model.haveWinner() && player.getIndex() == model.getLoser()) + continue; + player.stoneThrow = player.model.getStones(); + player.model.setStones(0); + delta += player.stoneThrow * player.model.getMultiplier(); + player.view.throwStones(player.stoneThrow); + if (player.stoneThrow != 0) { + noStones = false; + player.view.animateStones(player.stoneThrow); + player.view.updateStoneCounter(); + } } - else if (model.exhausted()) exhausted = true; - - if (disqual || victory || exhausted) endGame(); + if (noStones) { endGame(); return; } + model.moveTroll(delta); + view.moveTroll(); } private void endGame() { gameManager.endGame(); + if (model.haveWinner()) { + int loser = model.getLoser(); + gameManager.getPlayer(loser).view.defeat(); + } + Player p0 = gameManager.getPlayer(0); Player p1 = gameManager.getPlayer(1);