X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/b41b9823fbe2eed146db478fd5a1353bb558215c..9656502aaa68fb88bfc0664b0d60e8ed25a9acb0:/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 eaac5fb..dfa3324 100644 --- a/src/main/java/com/codingame/game/Referee.java +++ b/src/main/java/com/codingame/game/Referee.java @@ -24,6 +24,8 @@ public class Referee extends AbstractReferee { @Inject private View view; @Inject private Model model; + boolean disqual = false; + @Override public void init() { model.init(gameManager.getSeed()); @@ -31,7 +33,8 @@ public class Referee extends AbstractReferee { gameManager.getPlayer(1).model = model.p1; for (Player p: gameManager.getPlayers()) { - p.gameInit(model.roadLength, model.initialStones); + p.gameInit(model.roadLength, model.initialStones, + gameManager.getSeed()); } view.init(model); @@ -40,12 +43,23 @@ public class Referee extends AbstractReferee { 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.setScore(-1); + } + @Override public void gameTurn(int turn) { // System.err.println("Starting turn " + turn); 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(); } @@ -56,45 +70,39 @@ 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(); switch (player.type) { case Timeout: - gameManager.addToGameSummary(player.getNicknameToken() + " timed out!"); - player.deactivate(player.getNicknameToken() + " T/O"); - player.setScore(-1); + disqualify(player, "T/O", "timed out!"); + player.view.markTimeout(); disqual = true; break; case Invalid: - player.deactivate(player.getNicknameToken() + " INVALID"); - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " provided an ill-formed action")); - player.setScore(-1); + disqualify(player, "INVALID", "provided an ill-formed action"); + player.view.markIllegal(); disqual = true; break; case Throw: try { player.model.consumeStones(player.stoneThrow); } catch (Model.Player.ThrewMoreStonesThanHad e) { if (model.random.nextInt(10) > 0) { - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " tried to throw more stones than they had. I'll let it slide for this time. (But not let them throw that much!)")); + player.view.threwMoreStonesThanHad(); player.stoneThrow = player.model.consumeMaxStones(); } else { - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " tried to throw more stones than they had. They went into debt trying to provide. The economy tanked, recession and famine ensued; even the troll wouldn't have wanted to bash them anymore. But that's no victory.")); - player.deactivate(player.getNicknameToken() + " ILLEGAL"); - player.setScore(-1); + disqualify(player, "ILLEGAL", "tried to throw more stones than they had. They went into debt trying to provide. The economy tanked, recession and famine ensued; even the troll wouldn't have wanted to bash them anymore. But that's no victory."); + player.view.markIllegal(); disqual = true; } } catch (Model.Player.FailedToThrowStonesAndShouldHave e) { if (model.random.nextInt(10) > 0) { - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " tried not throwing any stones. Fixing that for them because I'm in a good mood today.")); + player.view.failedToThrowStonesAndShouldHave(); player.stoneThrow = player.model.consumeMinStones(); } else { - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + "tried not throwing any stones. They were then eaten by a grue.")); - player.deactivate(player.getNicknameToken() + " ILLEGAL"); - player.setScore(-1); + disqualify(player, "ILLEGAL", "tried not throwing any stones. They were then eaten by a grue."); disqual = true; } } @@ -114,71 +122,79 @@ public class Referee extends AbstractReferee { * exhaustion). */ int delta = 0; - boolean victory = false; - boolean exhausted = false; - if (! disqual) { - for (Player player : gameManager.getActivePlayers()) { - gameManager.addToGameSummary(String.format("%s throws %d stone%s at the troll.", player.getNicknameToken(), player.stoneThrow, player.stoneThrow == 1 ? "" : "s")); - delta += player.model.getMultiplier() * player.stoneThrow; - - if (player.stoneThrow < 0) { - player.deactivate(player.getNicknameToken() + " CHEAT"); - gameManager.addToGameSummary(GameManager.formatErrorMessage(player.getNicknameToken() + " cheated. Banning account.")); - player.setScore(-1); - disqual = true; - } - else if (player.stoneThrow > 0) { - player.view.animateStones(player.stoneThrow); - player.view.updateStoneCounter(); - } - } + for (Player player : gameManager.getActivePlayers()) { + player.view.throwStones(player.stoneThrow); + delta += player.model.getMultiplier() * player.stoneThrow; - /* 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. - * It would be unfair to have a cheating player "win" - * (earn the opponent castle destruction animation) this - * way. - */ - boolean cheat0 = gameManager.getPlayer(0).stoneThrow < 0; - boolean cheat1 = gameManager.getPlayer(1).stoneThrow < 0; - if (cheat0 && cheat1); // here we can actually keep delta's value - else if (cheat0) delta = -1; - else if (cheat1) delta = 1; - - if (delta > 0) { - gameManager.addToGameSummary("Troll walks right."); - model.trollPosition++; - } - else if (delta < 0) { - gameManager.addToGameSummary("Troll walks left."); - model.trollPosition--; + if (player.stoneThrow < 0) { + disqualify(player, "CHEAT", "cheated. Banning account."); + player.view.markCheat(); + disqual = true; } - else { - gameManager.addToGameSummary("Troll stands still."); - // XXX animate + if (player.stoneThrow != 0) { + player.view.animateStones(player.stoneThrow); + player.view.updateStoneCounter(); } - view.moveTroll(); + } - for (Player player : gameManager.getActivePlayers()) { - player.model.adjustScore(model.trollPosition); - } + /* 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. + * It would be unfair to have a cheating player "win" + * (earn the opponent castle destruction animation) this + * way. + */ + boolean cheat0 = gameManager.getPlayer(0).isActive() + && gameManager.getPlayer(0).stoneThrow < 0; + boolean cheat1 = gameManager.getPlayer(1).isActive() + && gameManager.getPlayer(1).stoneThrow < 0; + if (cheat0 && cheat1); // here we can actually keep delta's value + else if (cheat0) delta = -1; + else if (cheat1) delta = 1; + + if (delta > 0) { + model.moveTroll(+1); + view.moveTroll(View.Dir.RIGHT); + } + else if (delta < 0) { + model.moveTroll(-1); + view.moveTroll(View.Dir.LEFT); + } + else { + view.moveTroll(View.Dir.STILL); + // XXX animate + } + } - if (model.haveWinner()) { - int loser = model.getLoser(); - gameManager.addToGameSummary(GameManager.formatErrorMessage("Troll destroys " + gameManager.getPlayer(loser).getNicknameToken()) + "."); - victory = true; + // XXX very similar to main turn pendant + private void finishStones() { + boolean noStones = true; + int delta = 0; + for (Player player : gameManager.getActivePlayers()) { + 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); @@ -186,20 +202,20 @@ public class Referee extends AbstractReferee { int s1 = p1.getScore(); if (s0 > s1) { - gameManager.addToGameSummary(GameManager.formatSuccessMessage(p0.getNicknameToken() + " wins.")); - p1.view.destroy(); + p0.view.victory(); + p1.view.markLoser(); } else if (s0 < s1) { - gameManager.addToGameSummary(GameManager.formatSuccessMessage(p1.getNicknameToken() + " wins.")); - p0.view.destroy(); + p1.view.victory(); + p0.view.markLoser(); } else if (s0 < 0) { - gameManager.addToGameSummary(GameManager.formatErrorMessage("Everybody loses!")); - p0.view.destroy(); - p1.view.destroy(); + view.doubleDefeat(); + p0.view.markLoser(); + p1.view.markLoser(); } else { - gameManager.addToGameSummary("Draw."); + view.draw(); } } }