From a43812ed462630850edbf29bda182fbf1e5e1263 Mon Sep 17 00:00:00 2001 From: Joel Kronqvist Date: Thu, 14 Nov 2024 19:25:19 +0200 Subject: Immediate printing of actions & no prompt on blocking action & refactoring --- src/main/scala/Client/StdinLineReader.scala | 31 +++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 src/main/scala/Client/StdinLineReader.scala (limited to 'src/main/scala/Client/StdinLineReader.scala') diff --git a/src/main/scala/Client/StdinLineReader.scala b/src/main/scala/Client/StdinLineReader.scala new file mode 100644 index 0000000..42a1f40 --- /dev/null +++ b/src/main/scala/Client/StdinLineReader.scala @@ -0,0 +1,31 @@ +package o1game.Client + +import scala.concurrent.Future +import scala.concurrent.ExecutionContext.Implicits.global +import scala.io.StdIn.readLine +import scala.util.{Try, Success, Failure} + +/** This class is for taking new lines from stdin when they are available. + * reading starts when either newLine or clear or startReading are called. + */ +class StdinLineReader: + + private var nextLine: Future[String] = Future.failed(Exception()) + + /** Returns a new line of input if there are any. */ + def newLine(): Option[String] = + this.nextLine.value match + case Some(Success(s)) => + this.startReading() + Some(s) + case Some(Failure(e)) => + this.startReading() + None + case None => None + + /** Discards the line that is currently being read and restarts reading */ + def startReading(): Unit = + this.nextLine = Future(readLine()) + + +end StdinLineReader -- cgit v1.2.3