src/Tools/jEdit/src/document_dockable.scala
author wenzelm
Tue, 31 Jan 2023 17:08:16 +0100
changeset 77151 2f43be96c713
parent 77150 286fdf0fcc44
child 77152 4c9296390f20
permissions -rw-r--r--
removed unused operation from 3f50b24909df;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     1
/*  Title:      Tools/jEdit/src/document_dockable.scala
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     3
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     4
Dockable window for document build support.
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     5
*/
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     6
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     7
package isabelle.jedit
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     8
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
     9
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    10
import isabelle._
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    11
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    12
import java.awt.BorderLayout
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    13
import java.awt.event.{ComponentEvent, ComponentAdapter}
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    14
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    15
import scala.swing.{ScrollPane, TextArea, Label, TabbedPane, BorderPanel, Component}
76602
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
    16
import scala.swing.event.SelectionChanged
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    17
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    18
import org.gjt.sp.jedit.{jEdit, View}
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    19
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    20
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    21
object Document_Dockable {
76491
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
    22
  /* state */
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
    23
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    24
  object State {
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
    25
    def init(): State = State()
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    26
  }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    27
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    28
  sealed case class State(
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    29
    pending: Boolean = false,
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    30
    process: Future[Unit] = Future.value(()),
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    31
    progress: Progress = new Progress,
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    32
    output_results: Command.Results = Command.Results.empty,
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    33
    output_main: XML.Body = Nil,
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    34
    output_more: XML.Body = Nil
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
    35
  ) {
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    36
    def running: Boolean = !process.is_finished
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
    37
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
    38
    def run(process: Future[Unit], progress: Progress, reset_pending: Boolean): State =
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
    39
      copy(process = process, progress = progress, pending = if (reset_pending) false else pending)
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    40
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    41
    def output(results: Command.Results, body: XML.Body): State =
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    42
      copy(output_results = results, output_main = body)
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    43
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    44
    def finish(output: XML.Body): State =
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    45
      copy(process = Future.value(()), output_more = output)
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
    46
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    47
    def output_body: XML.Body =
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    48
      output_main :::
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    49
      (if (output_main.nonEmpty && output_more.nonEmpty) Pretty.Separator else Nil) :::
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    50
      output_more
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
    51
  }
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    52
}
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    53
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    54
class Document_Dockable(view: View, position: String) extends Dockable(view, position) {
76609
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 76606
diff changeset
    55
  dockable =>
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 76606
diff changeset
    56
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    57
  GUI_Thread.require {}
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    58
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    59
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    60
  /* component state -- owned by GUI thread */
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    61
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
    62
  private val current_state = Synchronized(Document_Dockable.State.init())
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    63
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    64
  private val process_indicator = new Process_Indicator
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    65
  private val pretty_text_area = new Pretty_Text_Area(view)
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    66
  private val message_pane = new TabbedPane
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    67
76034
dda3c117f13c clarified GUI behaviour;
wenzelm
parents: 76026
diff changeset
    68
  private def show_state(): Unit = GUI_Thread.later {
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    69
    val st = current_state.value
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    70
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    71
    pretty_text_area.update(Document.Snapshot.init, st.output_results, st.output_body)
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    72
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    73
    if (st.running) process_indicator.update("Running document build process ...", 15)
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    74
    else if (st.pending) process_indicator.update("Waiting for pending document content ...", 5)
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
    75
    else process_indicator.update(null, 0)
76034
dda3c117f13c clarified GUI behaviour;
wenzelm
parents: 76026
diff changeset
    76
  }
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    77
76034
dda3c117f13c clarified GUI behaviour;
wenzelm
parents: 76026
diff changeset
    78
  private def show_page(page: TabbedPane.Page): Unit = GUI_Thread.later {
dda3c117f13c clarified GUI behaviour;
wenzelm
parents: 76026
diff changeset
    79
    message_pane.selection.page = page
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    80
  }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    81
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    82
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    83
  /* text area with zoom/resize */
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    84
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    85
  override def detach_operation: Option[() => Unit] = pretty_text_area.detach_operation
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
    86
76021
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    87
  private val zoom = new Font_Info.Zoom { override def changed(): Unit = handle_resize() }
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    88
  private def handle_resize(): Unit = GUI_Thread.require { pretty_text_area.zoom(zoom) }
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    89
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    90
  private val delay_resize: Delay =
76610
6e2383488a55 clarified signature: proper scopes and types;
wenzelm
parents: 76609
diff changeset
    91
    Delay.first(PIDE.session.update_delay, gui = true) { handle_resize() }
76021
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    92
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    93
  addComponentListener(new ComponentAdapter {
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    94
    override def componentResized(e: ComponentEvent): Unit = delay_resize.invoke()
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    95
    override def componentShown(e: ComponentEvent): Unit = delay_resize.invoke()
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    96
  })
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
    97
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
    98
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
    99
  /* progress */
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   100
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   101
  class Log_Progress extends Program_Progress {
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   102
    progress =>
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   103
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   104
    override def detect_program(s: String): Option[String] =
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   105
      Document_Build.detect_running_script(s)
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   106
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   107
    private val delay: Delay =
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   108
      Delay.first(PIDE.session.output_delay) {
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   109
        if (!stopped) {
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
   110
          output_process(progress)
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   111
          GUI_Thread.later { show_state() }
76491
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
   112
        }
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   113
      }
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   114
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   115
    override def echo(msg: String): Unit = { super.echo(msg); delay.invoke() }
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   116
    override def stop_program(): Unit = { super.stop_program(); delay.invoke() }
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   117
  }
76021
752425c69577 clarified component structure, concerning initialization order;
wenzelm
parents: 75853
diff changeset
   118
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   119
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   120
  /* document build process */
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   121
76491
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
   122
  private def init_state(): Unit =
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   123
    current_state.change { st =>
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   124
      st.progress.stop()
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   125
      Document_Dockable.State(progress = new Log_Progress)
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   126
    }
76491
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
   127
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   128
  private def cancel_process(): Unit =
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   129
    current_state.change { st => st.process.cancel(); st }
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   130
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   131
  private def await_process(): Unit =
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   132
    current_state.guarded_access(st => if (st.process.is_finished) None else Some((), st))
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   133
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
   134
  private def output_process(progress: Log_Progress): Unit = {
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   135
    val (results, body) = progress.output()
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
   136
    current_state.change(_.output(results, body))
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   137
  }
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   138
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   139
  private def pending_process(): Unit =
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   140
    current_state.change { st =>
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   141
      if (st.pending) st
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   142
      else {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   143
        delay_auto_build.revoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   144
        delay_build.invoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   145
        st.copy(pending = true)
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   146
      }
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   147
    }
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   148
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   149
  private def finish_process(output: XML.Body): Unit =
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   150
    current_state.change { st =>
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   151
      if (st.pending) {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   152
        delay_auto_build.revoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   153
        delay_build.invoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   154
      }
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   155
      st.finish(output)
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   156
    }
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   157
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   158
  private def run_process(reset_pending: Boolean = false)(body: Log_Progress => Unit): Boolean = {
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   159
    val started =
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   160
      current_state.change_result { st =>
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   161
        if (st.process.is_finished) {
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   162
          st.progress.stop()
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   163
          val progress = new Log_Progress
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   164
          val process =
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   165
            Future.thread[Unit](name = "Document_Dockable.process") {
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   166
              await_process()
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   167
              body(progress)
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   168
            }
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   169
          (true, st.run(process, progress, reset_pending))
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   170
        }
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   171
        else (false, st)
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   172
      }
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   173
    show_state()
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   174
    started
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   175
  }
76716
a7602257a825 clarified state document nodes for Theories_Status / Document_Dockable;
wenzelm
parents: 76711
diff changeset
   176
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   177
  private def load_document(session: String): Boolean = {
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   178
    val options = PIDE.options.value
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   179
    run_process() { _ =>
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   180
      try {
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   181
        val session_background =
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   182
          Document_Build.session_background(
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   183
            options, session, dirs = JEdit_Sessions.session_dirs)
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   184
        PIDE.editor.document_setup(Some(session_background))
76716
a7602257a825 clarified state document nodes for Theories_Status / Document_Dockable;
wenzelm
parents: 76711
diff changeset
   185
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   186
        finish_process(Nil)
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   187
        GUI_Thread.later {
76725
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   188
          refresh_theories()
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   189
          show_state()
76996
6d847e27cafc tuned GUI;
wenzelm
parents: 76994
diff changeset
   190
          show_page(input_page)
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   191
        }
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   192
      }
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   193
      catch {
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   194
        case exn: Throwable if !Exn.is_interrupt(exn) =>
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   195
          finish_process(List(Protocol.error_message(Exn.print(exn))))
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   196
          GUI_Thread.later {
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   197
            show_state()
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   198
            show_page(output_page)
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   199
          }
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   200
      }
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   201
    }
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   202
  }
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   203
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   204
  private def document_build(
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   205
    document_session: Document_Editor.Session,
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   206
    progress: Log_Progress
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   207
  ): Unit = {
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   208
    val session_background = document_session.get_background
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   209
    val snapshot = document_session.get_snapshot
77022
ac5ebdf19861 clarified signature;
wenzelm
parents: 77008
diff changeset
   210
    val session_context = JEdit_Sessions.open_session_context(document_snapshot = Some(snapshot))
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   211
    try {
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   212
      val context =
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   213
        Document_Build.context(session_context,
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   214
          document_session = Some(session_background.base),
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   215
          document_selection = document_session.selection,
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   216
          progress = progress)
76994
7c23db6b857b more detailed Program_Progress / Log_Progress: each program gets its own log output, which is attached to the document via markup;
wenzelm
parents: 76769
diff changeset
   217
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   218
      Isabelle_System.make_directory(Document_Editor.document_output_dir())
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   219
      val doc = context.build_document(document_session.get_variant, verbose = true)
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   220
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   221
      File.write(Document_Editor.document_output().log, doc.log)
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   222
      Bytes.write(Document_Editor.document_output().pdf, doc.pdf)
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   223
      Document_Editor.view_document()
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   224
    }
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   225
    finally { session_context.close() }
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   226
  }
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   227
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   228
  private def document_build_attempt(): Boolean = {
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   229
    val document_session = PIDE.editor.document_session()
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   230
    if (document_session.is_vacuous) true
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   231
    else if (document_session.is_pending) false
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   232
    else {
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   233
      run_process(reset_pending = true) { progress =>
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   234
        show_page(output_page)
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   235
        val result = Exn.capture { document_build(document_session, progress) }
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   236
        val msgs =
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   237
          result match {
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   238
            case Exn.Res(_) =>
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   239
              List(Protocol.writeln_message("OK"))
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   240
            case Exn.Exn(exn: Document_Build.Build_Error) =>
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   241
              exn.log_errors.map(s => Protocol.error_message(YXML.parse_body(s)))
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   242
            case Exn.Exn(exn) =>
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   243
              List(Protocol.error_message(YXML.parse_body(Exn.print(exn))))
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   244
          }
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   245
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   246
        progress.stop_program()
77146
eb114301c4df clarified signature: prefer semantic status;
wenzelm
parents: 77145
diff changeset
   247
        output_process(progress)
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   248
        finish_process(Pretty.separate(msgs))
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76727
diff changeset
   249
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   250
        show_state()
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   251
        show_page(if (Exn.is_interrupt_exn(result)) input_page else output_page)
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   252
      }
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   253
      true
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   254
    }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   255
  }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   256
77144
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   257
  private lazy val delay_build: Delay =
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   258
    Delay.first(PIDE.session.output_delay, gui = true) {
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   259
      if (!document_build_attempt()) delay_build.invoke()
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   260
    }
42c3970e1ac1 clarified Document_Editor.Session: more explicit types, more robust operations;
wenzelm
parents: 77142
diff changeset
   261
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   262
  private lazy val delay_auto_build: Delay =
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   263
    Delay.last(PIDE.session.document_delay, gui = true) {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   264
      pending_process()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   265
    }
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   266
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   267
  private def document_pending() = current_state.value.pending
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   268
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   269
  private val document_auto = new JEdit_Options.Bool_Access("editor_document_auto")
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   270
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   271
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   272
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   273
  /* controls */
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   274
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   275
  private val document_session =
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   276
    JEdit_Sessions.document_selector(PIDE.options, standalone = true)
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   277
76602
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   278
  private lazy val delay_load: Delay =
76610
6e2383488a55 clarified signature: proper scopes and types;
wenzelm
parents: 76609
diff changeset
   279
    Delay.last(PIDE.session.load_delay, gui = true) {
76681
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   280
      for (session <- document_session.selection_value) {
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   281
        if (!load_document(session)) delay_load.invoke()
8ad17c4669da clarified state and process;
wenzelm
parents: 76680
diff changeset
   282
      }
76602
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   283
    }
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   284
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   285
  document_session.reactions += { case SelectionChanged(_) => delay_load.invoke() }
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   286
76726
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   287
  private val load_button =
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   288
    new GUI.Button("Load") {
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   289
      tooltip = "Load document theories"
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   290
      override def clicked(): Unit = PIDE.editor.document_select_all(set = true)
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   291
    }
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   292
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   293
  private val auto_build_button =
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   294
    new JEdit_Options.Bool_GUI(document_auto, "Auto") {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   295
      tooltip = Word.capitalize(document_auto.description)
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   296
      override def clicked(state: Boolean): Unit = {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   297
        super.clicked(state)
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   298
        if (state) delay_auto_build.invoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   299
      }
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   300
    }
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   301
75853
f981111768ec clarified signature;
wenzelm
parents: 75839
diff changeset
   302
  private val build_button =
f981111768ec clarified signature;
wenzelm
parents: 75839
diff changeset
   303
    new GUI.Button("<html><b>Build</b></html>") {
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   304
      tooltip = "Build document"
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   305
      override def clicked(): Unit = pending_process()
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   306
    }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   307
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   308
  private val cancel_button =
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   309
    new GUI.Button("Cancel") {
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   310
      tooltip = "Cancel build process"
76718
3f50b24909df clarified process management;
wenzelm
parents: 76716
diff changeset
   311
      override def clicked(): Unit = cancel_process()
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   312
    }
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   313
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   314
  private val view_button =
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   315
    new GUI.Button("View") {
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   316
      tooltip = "View document"
76606
3558388330f8 clarified modules;
wenzelm
parents: 76602
diff changeset
   317
      override def clicked(): Unit = Document_Editor.view_document()
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   318
    }
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   319
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   320
  private val controls =
76726
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   321
    Wrap_Panel(List(document_session, process_indicator.component, load_button,
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   322
      auto_build_button, build_button, view_button, cancel_button))
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   323
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   324
  add(controls.peer, BorderLayout.NORTH)
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   325
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   326
  override def focusOnDefaultComponent(): Unit = build_button.requestFocus()
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   327
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   328
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   329
  /* message pane with pages */
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   330
76726
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   331
  private val reset_button =
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   332
    new GUI.Button("Reset") {
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   333
      tooltip = "Deselect document theories"
76720
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   334
      override def clicked(): Unit = PIDE.editor.document_select_all(set = false)
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   335
    }
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   336
76726
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   337
  private val purge_button = new GUI.Button("Purge") {
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   338
    tooltip = "Remove theories that are no longer required"
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   339
    override def clicked(): Unit = PIDE.editor.purge()
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   340
  }
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   341
76720
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   342
  private val theories_controls =
76726
c83dfd565283 clarified GUI;
wenzelm
parents: 76725
diff changeset
   343
    Wrap_Panel(List(reset_button, purge_button))
76720
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   344
76602
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   345
  private val theories = new Theories_Status(view, document = true)
77008
60b465c4463c tuned GUI;
wenzelm
parents: 76996
diff changeset
   346
  private val theories_pane = new ScrollPane(theories.gui)
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   347
76725
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   348
  private def refresh_theories(): Unit = {
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   349
    val domain = PIDE.editor.document_theories().toSet
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   350
    theories.update(domain = Some(domain), trim = true, force = true)
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   351
    theories.refresh()
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   352
  }
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   353
76996
6d847e27cafc tuned GUI;
wenzelm
parents: 76994
diff changeset
   354
  private val input_page =
6d847e27cafc tuned GUI;
wenzelm
parents: 76994
diff changeset
   355
    new TabbedPane.Page("Input", new BorderPanel {
76720
37f7b2965e02 more GUI operations;
wenzelm
parents: 76719
diff changeset
   356
      layout(theories_controls) = BorderPanel.Position.North
77008
60b465c4463c tuned GUI;
wenzelm
parents: 76996
diff changeset
   357
      layout(theories_pane) = BorderPanel.Position.Center
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   358
    }, "Selection and status of document theories")
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   359
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   360
  private val output_controls =
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   361
    Wrap_Panel(List(pretty_text_area.search_label, pretty_text_area.search_field, zoom))
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   362
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   363
  private val output_page =
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   364
    new TabbedPane.Page("Output", new BorderPanel {
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   365
      layout(output_controls) = BorderPanel.Position.North
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   366
      layout(Component.wrap(pretty_text_area)) = BorderPanel.Position.Center
76996
6d847e27cafc tuned GUI;
wenzelm
parents: 76994
diff changeset
   367
    }, "Results from document build process")
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   368
76996
6d847e27cafc tuned GUI;
wenzelm
parents: 76994
diff changeset
   369
  message_pane.pages ++= List(input_page, output_page)
76023
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   370
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   371
  set_content(message_pane)
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   372
c7fed2fd52f5 more GUI functionality;
wenzelm
parents: 76021
diff changeset
   373
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   374
  /* main */
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   375
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   376
  private val main =
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   377
    Session.Consumer[Any](getClass.getName) {
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   378
      case _: Session.Global_Options =>
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   379
        GUI_Thread.later {
76578
06b001094ddb more uniform session selectors, with persistent options;
wenzelm
parents: 76577
diff changeset
   380
          document_session.load()
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   381
          handle_resize()
76725
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
   382
          refresh_theories()
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   383
        }
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   384
      case changed: Session.Commands_Changed =>
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   385
        GUI_Thread.later {
76719
2c8632c746fe proper handling of state updates;
wenzelm
parents: 76718
diff changeset
   386
          val domain = PIDE.editor.document_theories().filter(changed.nodes).toSet
77150
286fdf0fcc44 clarified guard: avoid spurious auto builds;
wenzelm
parents: 77149
diff changeset
   387
          if (domain.nonEmpty) {
286fdf0fcc44 clarified guard: avoid spurious auto builds;
wenzelm
parents: 77149
diff changeset
   388
            theories.update(domain = Some(domain))
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   389
77150
286fdf0fcc44 clarified guard: avoid spurious auto builds;
wenzelm
parents: 77149
diff changeset
   390
            val pending = document_pending()
286fdf0fcc44 clarified guard: avoid spurious auto builds;
wenzelm
parents: 77149
diff changeset
   391
            val auto = document_auto()
286fdf0fcc44 clarified guard: avoid spurious auto builds;
wenzelm
parents: 77149
diff changeset
   392
            if ((pending || auto) && PIDE.editor.document_session().is_ready) {
77149
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   393
              if (pending) {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   394
                delay_auto_build.revoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   395
                delay_build.invoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   396
              }
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   397
              else if (auto) {
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   398
                delay_auto_build.invoke()
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   399
              }
3991a35cd740 automatically build document when selected theories are finished;
wenzelm
parents: 77147
diff changeset
   400
            }
77147
38077c938d01 defer build until document nodes are ready;
wenzelm
parents: 77146
diff changeset
   401
          }
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   402
        }
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   403
    }
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   404
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   405
  override def init(): Unit = {
76701
3543ecb4c97d tuned signature;
wenzelm
parents: 76681
diff changeset
   406
    PIDE.editor.document_init(dockable)
76491
2c37c10d6884 clarified GUI state;
wenzelm
parents: 76490
diff changeset
   407
    init_state()
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   408
    PIDE.session.global_options += main
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   409
    PIDE.session.commands_changed += main
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   410
    handle_resize()
76602
b5dfe1551637 more specific GUI for document nodes;
wenzelm
parents: 76580
diff changeset
   411
    delay_load.invoke()
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   412
  }
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   413
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   414
  override def exit(): Unit = {
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   415
    PIDE.session.global_options -= main
76567
aef247025f07 more GUI elements;
wenzelm
parents: 76565
diff changeset
   416
    PIDE.session.commands_changed -= main
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   417
    delay_resize.revoke()
76701
3543ecb4c97d tuned signature;
wenzelm
parents: 76681
diff changeset
   418
    PIDE.editor.document_exit(dockable)
75816
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   419
  }
91f02f224b80 basic setup for document build panel;
wenzelm
parents:
diff changeset
   420
}