src/Pure/ML/ml_console.scala
author wenzelm
Mon, 30 Mar 2020 19:50:01 +0200
changeset 71632 c1bc38327bc2
parent 71598 269dc4bf1f40
child 71713 928fd852f3e2
permissions -rw-r--r--
clarified signature;
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)
71383
8313dca6dee9 misc tuning, following hint by IntelliJ;
wenzelm
parents: 69854
diff changeset
    50
      if (more_args.nonEmpty) getopts.usage()
62559
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
71594
8a298184f3f9 clarified signature;
wenzelm
parents: 71383
diff changeset
    53
      val sessions_structure = Sessions.load_structure(options, dirs = dirs)
71598
269dc4bf1f40 clarified signature;
wenzelm
parents: 71594
diff changeset
    54
      val store = Sessions.store(options)
71594
8a298184f3f9 clarified signature;
wenzelm
parents: 71383
diff changeset
    55
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    56
      // build logic
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    57
      if (!no_build && !raw_ml_system) {
64115
wenzelm
parents: 62754
diff changeset
    58
        val progress = new Console_Progress()
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    59
        val rc =
68331
7eaaa8f48331 clarified outermost progress.interrupt_handler;
wenzelm
parents: 68305
diff changeset
    60
          progress.interrupt_handler {
69854
cc0b3e177b49 system option "system_heaps" supersedes various command-line options for "system build mode";
wenzelm
parents: 68541
diff changeset
    61
            Build.build_logic(options, logic, build_heap = true, progress = progress, dirs = dirs)
68331
7eaaa8f48331 clarified outermost progress.interrupt_handler;
wenzelm
parents: 68305
diff changeset
    62
          }
68305
5321218147d3 clarified signature;
wenzelm
parents: 68209
diff changeset
    63
        if (rc != 0) sys.exit(rc)
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    64
      }
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
      // process loop
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    67
      val process =
71598
269dc4bf1f40 clarified signature;
wenzelm
parents: 71594
diff changeset
    68
        ML_Process(options, sessions_structure, store,
269dc4bf1f40 clarified signature;
wenzelm
parents: 71594
diff changeset
    69
          logic = logic, args = List("-i"), redirect = true,
62643
6f7ac44365d7 eliminated without magic name;
wenzelm
parents: 62641
diff changeset
    70
          modes = if (raw_ml_system) Nil else modes ::: List("ASCII"),
68209
aeffd8f1f079 support Store with options;
wenzelm
parents: 67846
diff changeset
    71
          raw_ml_system = raw_ml_system,
65431
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    72
          session_base =
4a3e6cda3b94 provide session base for "isabelle build" and "isabelle console" ML process;
wenzelm
parents: 64598
diff changeset
    73
            if (raw_ml_system) None
68541
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    74
            else Some(Sessions.base_info(
12b4b3bc585d command-line option for include_sessions;
wenzelm
parents: 68331
diff changeset
    75
              options, logic, dirs = dirs, include_sessions = include_sessions).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
71632
c1bc38327bc2 clarified signature;
wenzelm
parents: 71598
diff changeset
    84
c1bc38327bc2 clarified signature;
wenzelm
parents: 71598
diff changeset
    85
      val rc = process_result.join
c1bc38327bc2 clarified signature;
wenzelm
parents: 71598
diff changeset
    86
      if (rc != 0) sys.exit(rc)
62559
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    87
    }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    88
  }
83e815849a91 isabelle console is based on Isabelle/Scala;
wenzelm
parents:
diff changeset
    89
}