diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/main/scala/Client/Client.scala | 9 | ||||
-rw-r--r-- | src/main/scala/Model/Adventure.scala | 3 | ||||
-rw-r--r-- | src/main/scala/Server/Server.scala | 6 |
3 files changed, 10 insertions, 8 deletions
diff --git a/src/main/scala/Client/Client.scala b/src/main/scala/Client/Client.scala index e9d3074..7b0f8b2 100644 --- a/src/main/scala/Client/Client.scala +++ b/src/main/scala/Client/Client.scala @@ -17,7 +17,7 @@ import java.lang.System.currentTimeMillis /** A helper enum for `Client` to keep track of communications with the server */ enum ServerLineState: - case WaitingForGameStart, + case WaitingForTimeLimit, ActionDescription, TurnIndicator, AreaDescription, @@ -63,7 +63,7 @@ class Client(socket: Socket): private val serverLineParser = ReceivedLineParser() private val stdinReader = StdinLineReader() - private var serverLineState = ServerLineState.WaitingForGameStart + private var serverLineState = ServerLineState.WaitingForTimeLimit /** Variables about the status of the current turn for the client */ private var canAct = false @@ -140,12 +140,13 @@ class Client(socket: Socket): serverLineState match - case ServerLineState.WaitingForGameStart => + case ServerLineState.WaitingForTimeLimit => val time = line.toLongOption time match case Some(t) => this.timeLimit = t case None => print("Invalid time limit, oh no!!!") - this.serverLineState = ServerLineState.ActionDescription + this.serverLineState = ServerLineState.TurnIndicator + this.lastTurnStart = currentTimeMillis / 1000 case ServerLineState.ActionDescription => if line.head == ACTION_BLOCKING_INDICATOR then diff --git a/src/main/scala/Model/Adventure.scala b/src/main/scala/Model/Adventure.scala index 01f5d13..4d0a256 100644 --- a/src/main/scala/Model/Adventure.scala +++ b/src/main/scala/Model/Adventure.scala @@ -11,9 +11,6 @@ import scala.collection.mutable.Map * games, you will need to modify or replace the source code of this class. */ class Adventure(val playerNames: Vector[String]): - /** the name of the game */ - val title = "A Forest Adventure" - private val middle = Area("Forest", "You are somewhere in the forest. There are a lot of trees here.\nBirds are singing.") private val northForest = Area("Forest", "You are somewhere in the forest. A tangle of bushes blocks further passage north.\nBirds are singing.") private val southForest = Area("Forest", "The forest just goes on and on.") diff --git a/src/main/scala/Server/Server.scala b/src/main/scala/Server/Server.scala index a03bc53..5eb15cb 100644 --- a/src/main/scala/Server/Server.scala +++ b/src/main/scala/Server/Server.scala @@ -82,13 +82,17 @@ class Server( assert(this.adventure.isDefined) c.gameStart() val name = c.getName + val entity: Option[Entity] = name match case Some(n) => this.adventure match case Some(a) => a.getPlayer(n) case None => None case None => None entity.foreach(c.giveEntity(_)) - this.writeToClient(s"$timeLimit\r\n", c) + + this.writeToClient( + s"$timeLimit\r\n${this.turnStartInfo(c)}", c + ) /** Helper function to determine if the next turn can be taken */ |