src/Tools/jEdit/src/session_dockable.scala
author wenzelm
Fri, 19 Aug 2011 13:55:32 +0200
changeset 45172 b3bd26fd22d3
parent 44603 fad8634cee62
child 45215 156be0e43336
permissions -rw-r--r--
editable raw text areas: allow user to clear content;
wenzelm@44162
     1
/*  Title:      Tools/jEdit/src/session_dockable.scala
wenzelm@39784
     2
    Author:     Makarius
wenzelm@39784
     3
wenzelm@39784
     4
Dockable window for prover session management.
wenzelm@39784
     5
*/
wenzelm@39784
     6
wenzelm@39784
     7
package isabelle.jedit
wenzelm@39784
     8
wenzelm@39784
     9
wenzelm@39784
    10
import isabelle._
wenzelm@39784
    11
wenzelm@39784
    12
import scala.actors.Actor._
wenzelm@40027
    13
import scala.swing.{FlowPanel, Button, TextArea, Label, ScrollPane, TabbedPane, Component, Swing}
wenzelm@39928
    14
import scala.swing.event.{ButtonClicked, SelectionChanged}
wenzelm@39857
    15
wenzelm@44400
    16
import java.lang.System
wenzelm@39857
    17
import java.awt.BorderLayout
wenzelm@39962
    18
import javax.swing.border.{BevelBorder, SoftBevelBorder}
wenzelm@39784
    19
wenzelm@39784
    20
import org.gjt.sp.jedit.View
wenzelm@39784
    21
wenzelm@39784
    22
wenzelm@39784
    23
class Session_Dockable(view: View, position: String) extends Dockable(view: View, position: String)
wenzelm@39784
    24
{
wenzelm@39855
    25
  /* main tabs */
wenzelm@39855
    26
wenzelm@44532
    27
  private val readme = new HTML_Panel("SansSerif", 14)
wenzelm@44532
    28
  readme.render_document(Isabelle_System.try_read(List(Path.explode("$JEDIT_HOME/README.html"))))
wenzelm@39855
    29
wenzelm@39919
    30
  private val syslog = new TextArea(Isabelle.session.syslog())
wenzelm@39855
    31
wenzelm@39855
    32
  private val tabs = new TabbedPane {
wenzelm@39855
    33
    pages += new TabbedPane.Page("README", Component.wrap(readme))
wenzelm@39855
    34
    pages += new TabbedPane.Page("System log", new ScrollPane(syslog))
wenzelm@39928
    35
wenzelm@39928
    36
    selection.index =
wenzelm@39928
    37
    {
wenzelm@39928
    38
      val index = Isabelle.Int_Property("session-panel.selection", 0)
wenzelm@39928
    39
      if (index >= pages.length) 0 else index
wenzelm@39928
    40
    }
wenzelm@39928
    41
    listenTo(selection)
wenzelm@39928
    42
    reactions += {
wenzelm@39928
    43
      case SelectionChanged(_) =>
wenzelm@39928
    44
        Isabelle.Int_Property("session-panel.selection") = selection.index
wenzelm@39928
    45
    }
wenzelm@39855
    46
  }
wenzelm@39855
    47
wenzelm@39855
    48
  set_content(tabs)
wenzelm@39784
    49
wenzelm@39784
    50
wenzelm@39857
    51
  /* controls */
wenzelm@39857
    52
wenzelm@39925
    53
  val session_phase = new Label(Isabelle.session.phase.toString)
wenzelm@39962
    54
  session_phase.border = new SoftBevelBorder(BevelBorder.LOWERED)
wenzelm@39962
    55
  session_phase.tooltip = "Prover status"
wenzelm@39925
    56
wenzelm@40027
    57
  private val interrupt = new Button("Interrupt") {
wenzelm@40027
    58
    reactions += { case ButtonClicked(_) => Isabelle.session.interrupt }
wenzelm@39967
    59
  }
wenzelm@40027
    60
  interrupt.tooltip = "Broadcast interrupt to all prover tasks"
wenzelm@39967
    61
wenzelm@39967
    62
  private val logic = Isabelle.logic_selector(Isabelle.Property("logic"))
wenzelm@39967
    63
  logic.listenTo(logic.selection)
wenzelm@39967
    64
  logic.reactions += {
wenzelm@39967
    65
    case SelectionChanged(_) => Isabelle.Property("logic") = logic.selection.item.name
wenzelm@39967
    66
  }
wenzelm@39967
    67
wenzelm@39925
    68
  private val controls =
wenzelm@40027
    69
    new FlowPanel(FlowPanel.Alignment.Right)(session_phase, interrupt, logic)
wenzelm@39857
    70
  add(controls.peer, BorderLayout.NORTH)
wenzelm@39857
    71
wenzelm@39857
    72
wenzelm@39784
    73
  /* main actor */
wenzelm@39784
    74
wenzelm@39784
    75
  private val main_actor = actor {
wenzelm@39784
    76
    loop {
wenzelm@39784
    77
      react {
wenzelm@44603
    78
        case input: Isabelle_Process.Input =>
wenzelm@44603
    79
wenzelm@39853
    80
        case result: Isabelle_Process.Result =>
wenzelm@39915
    81
          if (result.is_syslog)
wenzelm@39915
    82
            Swing_Thread.now {
wenzelm@39919
    83
              val text = Isabelle.session.syslog()
wenzelm@39916
    84
              if (text != syslog.text) {
wenzelm@39916
    85
                syslog.text = text
wenzelm@39916
    86
              }
wenzelm@39915
    87
            }
wenzelm@39853
    88
wenzelm@39966
    89
        case phase: Session.Phase =>
wenzelm@39961
    90
          Swing_Thread.now { session_phase.text = " " + phase.toString + " " }
wenzelm@39925
    91
wenzelm@39784
    92
        case bad => System.err.println("Session_Dockable: ignoring bad message " + bad)
wenzelm@39784
    93
      }
wenzelm@39784
    94
    }
wenzelm@39784
    95
  }
wenzelm@39784
    96
wenzelm@39925
    97
  override def init() {
wenzelm@39925
    98
    Isabelle.session.raw_messages += main_actor
wenzelm@39925
    99
    Isabelle.session.phase_changed += main_actor
wenzelm@39925
   100
  }
wenzelm@39925
   101
wenzelm@39925
   102
  override def exit() {
wenzelm@39925
   103
    Isabelle.session.raw_messages -= main_actor
wenzelm@39925
   104
    Isabelle.session.phase_changed -= main_actor
wenzelm@39925
   105
  }
wenzelm@39784
   106
}