author | wenzelm |
Thu, 23 Jun 2011 14:52:32 +0200 | |
changeset 43520 | cec9b95fa35d |
parent 43282 | 5d294220ca43 |
child 43606 | e1a09c2a6248 |
permissions | -rw-r--r-- |
43282
5d294220ca43
moved sources -- eliminated Netbeans artifact of jedit package directory;
wenzelm
parents:
39736
diff
changeset
|
1 |
/* Title: Tools/jEdit/src/session_dockable.scala |
39515 | 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._ |
|
39734 | 13 |
import scala.swing.{FlowPanel, Button, TextArea, Label, ScrollPane, TabbedPane, Component, Swing} |
39638 | 14 |
import scala.swing.event.{ButtonClicked, SelectionChanged} |
39593 | 15 |
|
43520
cec9b95fa35d
explicit import java.lang.System to prevent odd scope problems;
wenzelm
parents:
43282
diff
changeset
|
16 |
import java.lang.System |
39593 | 17 |
import java.awt.BorderLayout |
39697 | 18 |
import javax.swing.border.{BevelBorder, SoftBevelBorder} |
39515 | 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 |
{ |
|
39591 | 25 |
/* main tabs */ |
26 |
||
39736 | 27 |
private val readme = new HTML_Panel(Isabelle.system, "SansSerif", 14) |
39591 | 28 |
readme.render_document(Isabelle.system.try_read(List("$JEDIT_HOME/README.html"))) |
29 |
||
39629 | 30 |
private val syslog = new TextArea(Isabelle.session.syslog()) |
39591 | 31 |
syslog.editable = false |
32 |
||
33 |
private val tabs = new TabbedPane { |
|
34 |
pages += new TabbedPane.Page("README", Component.wrap(readme)) |
|
35 |
pages += new TabbedPane.Page("System log", new ScrollPane(syslog)) |
|
39638 | 36 |
|
37 |
selection.index = |
|
38 |
{ |
|
39 |
val index = Isabelle.Int_Property("session-panel.selection", 0) |
|
40 |
if (index >= pages.length) 0 else index |
|
41 |
} |
|
42 |
listenTo(selection) |
|
43 |
reactions += { |
|
44 |
case SelectionChanged(_) => |
|
45 |
Isabelle.Int_Property("session-panel.selection") = selection.index |
|
46 |
} |
|
39591 | 47 |
} |
48 |
||
49 |
set_content(tabs) |
|
39515 | 50 |
|
51 |
||
39593 | 52 |
/* controls */ |
53 |
||
39635 | 54 |
val session_phase = new Label(Isabelle.session.phase.toString) |
39697 | 55 |
session_phase.border = new SoftBevelBorder(BevelBorder.LOWERED) |
56 |
session_phase.tooltip = "Prover status" |
|
39635 | 57 |
|
39734 | 58 |
private val interrupt = new Button("Interrupt") { |
59 |
reactions += { case ButtonClicked(_) => Isabelle.session.interrupt } |
|
39702 | 60 |
} |
39734 | 61 |
interrupt.tooltip = "Broadcast interrupt to all prover tasks" |
39702 | 62 |
|
63 |
private val logic = Isabelle.logic_selector(Isabelle.Property("logic")) |
|
64 |
logic.listenTo(logic.selection) |
|
65 |
logic.reactions += { |
|
66 |
case SelectionChanged(_) => Isabelle.Property("logic") = logic.selection.item.name |
|
67 |
} |
|
68 |
||
39635 | 69 |
private val controls = |
39734 | 70 |
new FlowPanel(FlowPanel.Alignment.Right)(session_phase, interrupt, logic) |
39593 | 71 |
add(controls.peer, BorderLayout.NORTH) |
72 |
||
73 |
||
39515 | 74 |
/* main actor */ |
75 |
||
76 |
private val main_actor = actor { |
|
77 |
loop { |
|
78 |
react { |
|
39589 | 79 |
case result: Isabelle_Process.Result => |
39625 | 80 |
if (result.is_syslog) |
81 |
Swing_Thread.now { |
|
39629 | 82 |
val text = Isabelle.session.syslog() |
39626
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
83 |
if (text != syslog.text) { |
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
84 |
syslog.text = text |
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
85 |
} |
39625 | 86 |
} |
39589 | 87 |
|
39701 | 88 |
case phase: Session.Phase => |
39696 | 89 |
Swing_Thread.now { session_phase.text = " " + phase.toString + " " } |
39635 | 90 |
|
39515 | 91 |
case bad => System.err.println("Session_Dockable: ignoring bad message " + bad) |
92 |
} |
|
93 |
} |
|
94 |
} |
|
95 |
||
39635 | 96 |
override def init() { |
97 |
Isabelle.session.raw_messages += main_actor |
|
98 |
Isabelle.session.phase_changed += main_actor |
|
99 |
} |
|
100 |
||
101 |
override def exit() { |
|
102 |
Isabelle.session.raw_messages -= main_actor |
|
103 |
Isabelle.session.phase_changed -= main_actor |
|
104 |
} |
|
39515 | 105 |
} |