src/Pure/System/tty_loop.scala
author wenzelm
Mon, 12 Mar 2018 11:30:43 +0100
changeset 67836 74958337214d
parent 67833 e135d03f656f
child 67839 0c2ed45ece20
permissions -rw-r--r--
tuned signature -- more generic;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/System/tty_loop.scala
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     3
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     4
Line-oriented TTY loop.
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     5
*/
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     6
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     7
package isabelle
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     8
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
     9
67836
74958337214d tuned signature -- more generic;
wenzelm
parents: 67833
diff changeset
    10
import java.io.{IOException, Writer, Reader, InputStreamReader, BufferedReader}
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    11
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    12
67836
74958337214d tuned signature -- more generic;
wenzelm
parents: 67833
diff changeset
    13
class TTY_Loop(writer: Writer, reader: Reader, interrupt: Option[() => Unit] = None)
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    14
{
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    15
  private val console_output = Future.thread[Unit]("console_output") {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    16
    try {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    17
      var result = new StringBuilder(100)
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    18
      var finished = false
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    19
      while (!finished) {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    20
        var c = -1
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    21
        var done = false
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    22
        while (!done && (result.length == 0 || reader.ready)) {
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    23
          c = reader.read
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    24
          if (c >= 0) result.append(c.asInstanceOf[Char])
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    25
          else done = true
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    26
        }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    27
        if (result.length > 0) {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    28
          System.out.print(result.toString)
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    29
          System.out.flush()
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    30
          result.length = 0
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    31
        }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    32
        else {
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    33
          reader.close()
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    34
          finished = true
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    35
        }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    36
      }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    37
    }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    38
    catch { case e: IOException => case Exn.Interrupt() => }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    39
  }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    40
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    41
  private val console_input = Future.thread[Unit]("console_input") {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    42
    val console_reader = new BufferedReader(new InputStreamReader(System.in))
67808
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67802
diff changeset
    43
    def body
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67802
diff changeset
    44
    {
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    45
      try {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    46
        var finished = false
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    47
        while (!finished) {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    48
          console_reader.readLine() match {
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    49
            case null =>
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    50
              writer.close()
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    51
              finished = true
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    52
            case line =>
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    53
              writer.write(line)
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    54
              writer.write("\n")
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    55
              writer.flush()
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    56
          }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    57
        }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    58
      }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    59
      catch { case e: IOException => case Exn.Interrupt() => }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    60
    }
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    61
    interrupt match {
67808
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67802
diff changeset
    62
      case None => body
67833
e135d03f656f tuned signature;
wenzelm
parents: 67808
diff changeset
    63
      case Some(int) => POSIX_Interrupt.handler { int() } { body }
67808
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67802
diff changeset
    64
    }
67802
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    65
  }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    66
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    67
  def join { console_output.join; console_input.join }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    68
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    69
  def cancel { console_input.cancel }
32d76f08023f more general TTY loop;
wenzelm
parents:
diff changeset
    70
}