src/Pure/ML/ml_console.scala
author nipkow
Tue, 05 Nov 2019 14:57:41 +0100
changeset 71033 c1b63124245c
parent 69854 cc0b3e177b49
child 71383 8313dca6dee9
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
68541
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    18
      var include_sessions: List[String] = Nil
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    19
      var logic = Isabelle_System.getenv("ISABELLE_LOGIC")
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    20
      var modes: List[String] = Nil
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    21
      var no_build = false
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    22
      var options = Options.init()
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    23
      var raw_ml_system = false
62559
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
68541
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    30
    -i NAME      include session in name-space of theories
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    31
    -l NAME      logic session name (default ISABELLE_LOGIC=""" + quote(logic) + """)
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    32
    -m MODE      add print mode for output
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    33
    -n           no build of session image on startup
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    34
    -o OPTION    override Isabelle system OPTION (via NAME=VAL or NAME)
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    35
    -r           bootstrap from raw Poly/ML
62559
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))),
68541
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    42
        "i:" -> (arg => include_sessions = include_sessions ::: List(arg)),
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    43
        "l:" -> (arg => logic = arg),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    44
        "m:" -> (arg => modes = arg :: modes),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    45
        "n" -> (arg => no_build = true),
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    46
        "o:" -> (arg => options = options + arg),
69854
cc0b3e177b49 system option "system_heaps" supersedes various command-line options for "system build mode";
wenzelm
parents: 68541
diff changeset
    47
        "r" -> (_ => raw_ml_system = true))
62559
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
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    53
      // build logic
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    54
      if (!no_build && !raw_ml_system) {
64115
wenzelm
parents: 62754
diff changeset
    55
        val progress = new Console_Progress()
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    56
        val rc =
68331
7eaaa8f48331 clarified outermost progress.interrupt_handler;
wenzelm
parents: 68305
diff changeset
    57
          progress.interrupt_handler {
69854
cc0b3e177b49 system option "system_heaps" supersedes various command-line options for "system build mode";
wenzelm
parents: 68541
diff changeset
    58
            Build.build_logic(options, logic, build_heap = true, progress = progress, dirs = dirs)
68331
7eaaa8f48331 clarified outermost progress.interrupt_handler;
wenzelm
parents: 68305
diff changeset
    59
          }
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    60
        if (rc != 0) sys.exit(rc)
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    61
      }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    62
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    63
      // process loop
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    64
      val process =
64598
476e89d06272 expose stderr, e.g. Multithreading.tracing;
wenzelm
parents: 64115
diff changeset
    65
        ML_Process(options, logic = logic, args = List("-i"), dirs = dirs, redirect = true,
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    66
          modes = if (raw_ml_system) Nil else modes ::: List("ASCII"),
68209
aeffd8f1f079 support Store with options;
wenzelm
parents: 67846
diff changeset
    67
          raw_ml_system = raw_ml_system,
69854
cc0b3e177b49 system option "system_heaps" supersedes various command-line options for "system build mode";
wenzelm
parents: 68541
diff changeset
    68
          store = Some(Sessions.store(options)),
65431
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    69
          session_base =
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    70
            if (raw_ml_system) None
68541
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    71
            else Some(Sessions.base_info(
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    72
              options, logic, dirs = dirs, include_sessions = include_sessions).check_base))
67802
32d76f08023f more general TTY loop;
wenzelm
parents: 66989
diff changeset
    73
67808
9cb7f5f0bf41 clarified interrupt handling;
wenzelm
parents: 67803
diff changeset
    74
      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
    75
      val process_result = Future.thread[Int]("process_result") {
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    76
        val rc = process.join
67803
1cf4126d7bd9 more comments;
wenzelm
parents: 67802
diff changeset
    77
        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
    78
        rc
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    79
      }
67802
32d76f08023f more general TTY loop;
wenzelm
parents: 66989
diff changeset
    80
      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
    81
      process_result.join
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    82
    }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    83
  }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    84
}