diff options
-rw-r--r-- | core/src/ch/asynk/rustanddust/game/ctrl/Solo.java | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/core/src/ch/asynk/rustanddust/game/ctrl/Solo.java b/core/src/ch/asynk/rustanddust/game/ctrl/Solo.java index 1a7a0af..bcafe29 100644 --- a/core/src/ch/asynk/rustanddust/game/ctrl/Solo.java +++ b/core/src/ch/asynk/rustanddust/game/ctrl/Solo.java @@ -6,6 +6,8 @@ import ch.asynk.rustanddust.game.Battle; public class Solo extends Ctrl { + private int gameId; + public Solo(final RustAndDust game, final Battle battle) { super(game, battle); @@ -14,12 +16,32 @@ public class Solo extends Ctrl @Override public void init() { - battle.init(this, 0, 1); + gameId = game.config.gameId; + if (gameId == game.db.NO_RECORDS) { + int me = game.backend.getMyId(); + int other = game.backend.getOpponentId(); + gameId = game.db.storeGameGetId(me, other, battle.getId(), game.config.gameMode.i); + battle.init(this, me, other); + } else { + battle.init(this, game.db.loadState(gameId)); + } } @Override - protected void processAction() { } + protected void processAction() + { + storeState(); + } @Override - protected void processTurn() { } + protected void processTurn() + { + // TODO must store Orders in turns table + storeState(); + } + + private void storeState() + { + game.db.storeState(gameId, battle.getPlayer().getId(), battle.getOpponent().getId(), battle.unload()); + } } |