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