author | wenzelm |
Wed, 08 Jun 2011 17:42:07 +0200 | |
changeset 43282 | 5d294220ca43 |
parent 39736 | src/Tools/jEdit/src/jedit/session_dockable.scala@e19cece7d18a |
child 43520 | cec9b95fa35d |
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 |
|
16 |
import java.awt.BorderLayout |
|
39697 | 17 |
import javax.swing.border.{BevelBorder, SoftBevelBorder} |
39515 | 18 |
|
19 |
import org.gjt.sp.jedit.View |
|
20 |
||
21 |
||
22 |
class Session_Dockable(view: View, position: String) extends Dockable(view: View, position: String) |
|
23 |
{ |
|
39591 | 24 |
/* main tabs */ |
25 |
||
39736 | 26 |
private val readme = new HTML_Panel(Isabelle.system, "SansSerif", 14) |
39591 | 27 |
readme.render_document(Isabelle.system.try_read(List("$JEDIT_HOME/README.html"))) |
28 |
||
39629 | 29 |
private val syslog = new TextArea(Isabelle.session.syslog()) |
39591 | 30 |
syslog.editable = false |
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)) |
|
39638 | 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 |
} |
|
39591 | 46 |
} |
47 |
||
48 |
set_content(tabs) |
|
39515 | 49 |
|
50 |
||
39593 | 51 |
/* controls */ |
52 |
||
39635 | 53 |
val session_phase = new Label(Isabelle.session.phase.toString) |
39697 | 54 |
session_phase.border = new SoftBevelBorder(BevelBorder.LOWERED) |
55 |
session_phase.tooltip = "Prover status" |
|
39635 | 56 |
|
39734 | 57 |
private val interrupt = new Button("Interrupt") { |
58 |
reactions += { case ButtonClicked(_) => Isabelle.session.interrupt } |
|
39702 | 59 |
} |
39734 | 60 |
interrupt.tooltip = "Broadcast interrupt to all prover tasks" |
39702 | 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 |
||
39635 | 68 |
private val controls = |
39734 | 69 |
new FlowPanel(FlowPanel.Alignment.Right)(session_phase, interrupt, logic) |
39593 | 70 |
add(controls.peer, BorderLayout.NORTH) |
71 |
||
72 |
||
39515 | 73 |
/* main actor */ |
74 |
||
75 |
private val main_actor = actor { |
|
76 |
loop { |
|
77 |
react { |
|
39589 | 78 |
case result: Isabelle_Process.Result => |
39625 | 79 |
if (result.is_syslog) |
80 |
Swing_Thread.now { |
|
39629 | 81 |
val text = Isabelle.session.syslog() |
39626
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
82 |
if (text != syslog.text) { |
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
83 |
syslog.text = text |
a5d0bcfb95a3
manage persistent syslog via Session, not Isabelle_Process;
wenzelm
parents:
39625
diff
changeset
|
84 |
} |
39625 | 85 |
} |
39589 | 86 |
|
39701 | 87 |
case phase: Session.Phase => |
39696 | 88 |
Swing_Thread.now { session_phase.text = " " + phase.toString + " " } |
39635 | 89 |
|
39515 | 90 |
case bad => System.err.println("Session_Dockable: ignoring bad message " + bad) |
91 |
} |
|
92 |
} |
|
93 |
} |
|
94 |
||
39635 | 95 |
override def init() { |
96 |
Isabelle.session.raw_messages += main_actor |
|
97 |
Isabelle.session.phase_changed += main_actor |
|
98 |
} |
|
99 |
||
100 |
override def exit() { |
|
101 |
Isabelle.session.raw_messages -= main_actor |
|
102 |
Isabelle.session.phase_changed -= main_actor |
|
103 |
} |
|
39515 | 104 |
} |