src/Pure/ML/ml_console.scala
author wenzelm
Tue, 13 Mar 2018 18:28:12 +0100
changeset 67846 bdf6933f7ac9
parent 67808 9cb7f5f0bf41
child 68209 aeffd8f1f079
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
65477
64e61b0f6972 clarified directories;
wenzelm
parents: 65431
diff changeset
     1
/*  Title:      Pure/ML/ml_console.scala
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     3
62588
cd266473b81b isabelle_process is superseded by "isabelle process" tool;
wenzelm
parents: 62586
diff changeset
     4
The raw ML process in interactive mode.
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     5
*/
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     6
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     7
package isabelle
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     8
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
     9
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    10
object ML_Console
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    11
{
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    12
  /* command line entry point */
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    13
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    14
  def main(args: Array[String])
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    15
  {
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    16
    Command_Line.tool {
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    17
      var dirs: List[Path] = Nil
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    18
      var logic = Isabelle_System.getenv("ISABELLE_LOGIC")
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    19
      var modes: List[String] = Nil
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    20
      var no_build = false
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    21
      var options = Options.init()
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    22
      var raw_ml_system = false
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    23
      var system_mode = false
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    24
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    25
      val getopts = Getopts("""
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    26
Usage: isabelle console [OPTIONS]
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    27
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    28
  Options are:
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    29
    -d DIR       include session directory
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    30
    -l NAME      logic session name (default ISABELLE_LOGIC=""" + quote(logic) + """)
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    31
    -m MODE      add print mode for output
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    32
    -n           no build of session image on startup
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    33
    -o OPTION    override Isabelle system OPTION (via NAME=VAL or NAME)
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    34
    -r           bootstrap from raw Poly/ML
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    35
    -s           system build mode for session image
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    36
62588
cd266473b81b isabelle_process is superseded by "isabelle process" tool;
wenzelm
parents: 62586
diff changeset
    37
  Build a logic session image and run the raw Isabelle ML process
cd266473b81b isabelle_process is superseded by "isabelle process" tool;
wenzelm
parents: 62586
diff changeset
    38
  in interactive mode, with line editor ISABELLE_LINE_EDITOR=""" +
cd266473b81b isabelle_process is superseded by "isabelle process" tool;
wenzelm
parents: 62586
diff changeset
    39
  quote(Isabelle_System.getenv("ISABELLE_LINE_EDITOR")) + """.
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    40
""",
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    41
        "d:" -> (arg => dirs = dirs ::: List(Path.explode(arg))),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    42
        "l:" -> (arg => logic = arg),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    43
        "m:" -> (arg => modes = arg :: modes),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    44
        "n" -> (arg => no_build = true),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    45
        "o:" -> (arg => options = options + arg),
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    46
        "r" -> (_ => raw_ml_system = true),
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    47
        "s" -> (_ => system_mode = true))
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    48
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    49
      val more_args = getopts(args)
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    50
      if (!more_args.isEmpty) getopts.usage()
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    51
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    52
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    53
      // build
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    54
      if (!no_build && !raw_ml_system &&
67846
wenzelm
parents: 67808
diff changeset
    55
          !Build.build(options, build_heap = true, no_build = true,
62641
0b1b7465f2ef always build with full results;
wenzelm
parents: 62634
diff changeset
    56
            dirs = dirs, system_mode = system_mode, sessions = List(logic)).ok)
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    57
      {
64115
wenzelm
parents: 62754
diff changeset
    58
        val progress = new Console_Progress()
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    59
        progress.echo("Build started for Isabelle/" + logic + " ...")
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    60
        progress.interrupt_handler {
62641
0b1b7465f2ef always build with full results;
wenzelm
parents: 62634
diff changeset
    61
          val res =
67846
wenzelm
parents: 67808
diff changeset
    62
            Build.build(options, progress = progress, build_heap = true,
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    63
              dirs = dirs, system_mode = system_mode, sessions = List(logic))
62641
0b1b7465f2ef always build with full results;
wenzelm
parents: 62634
diff changeset
    64
          if (!res.ok) sys.exit(res.rc)
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    65
        }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    66
      }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    67
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    68
      // process loop
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    69
      val process =
64598
476e89d06272 expose stderr, e.g. Multithreading.tracing;
wenzelm
parents: 64115
diff changeset
    70
        ML_Process(options, logic = logic, args = List("-i"), dirs = dirs, redirect = true,
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    71
          modes = if (raw_ml_system) Nil else modes ::: List("ASCII"),
65431
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    72
          raw_ml_system = raw_ml_system, store = Sessions.store(system_mode),
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    73
          session_base =
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    74
            if (raw_ml_system) None
66989
wenzelm
parents: 66976
diff changeset
    75
            else Some(Sessions.base_info(options, logic, dirs = dirs).check_base))
67802
32d76f08023f more general TTY loop;
wenzelm
parents: 66989
diff changeset
    76
67808
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67803
diff changeset
    77
      val tty_loop = new TTY_Loop(process.stdin, process.stdout, Some(process.interrupt _))
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    78
      val process_result = Future.thread[Int]("process_result") {
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    79
        val rc = process.join
67803
1cf4126d7bd9 more comments;
wenzelm
parents: 67802
diff changeset
    80
        tty_loop.cancel  // FIXME does not quite work, cannot interrupt blocking read on System.in
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    81
        rc
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    82
      }
67802
32d76f08023f more general TTY loop;
wenzelm
parents: 66989
diff changeset
    83
      tty_loop.join
62562
905a5db3932d back to external line editor, due to problems of JLine with multithreading of in vs. out;
wenzelm
parents: 62561
diff changeset
    84
      process_result.join
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    85
    }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    86
  }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    87
}