author | wenzelm |
Sun, 01 Mar 2020 21:52:21 +0100 | |
changeset 71499 | 29f37eb9bd0f |
parent 71497 | a80fa14bccb8 |
child 71502 | f61e55bab00c |
permissions | -rw-r--r-- |
50208 | 1 |
/* Title: Tools/jEdit/src/isabelle.scala |
50183 | 2 |
Author: Makarius |
3 |
||
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
4 |
Global configuration and convenience operations for Isabelle/jEdit. |
50183 | 5 |
*/ |
6 |
||
7 |
package isabelle.jedit |
|
8 |
||
9 |
||
10 |
import isabelle._ |
|
11 |
||
71497 | 12 |
import java.awt.{Frame, Point} |
57627
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
13 |
|
53715 | 14 |
import scala.swing.CheckBox |
15 |
import scala.swing.event.ButtonClicked |
|
16 |
||
50198
0c7b351a6871
added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents:
50187
diff
changeset
|
17 |
import org.gjt.sp.jedit.{jEdit, View, Buffer} |
59074 | 18 |
import org.gjt.sp.jedit.buffer.JEditBuffer |
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
19 |
import org.gjt.sp.jedit.textarea.{JEditTextArea, TextArea, StructureMatcher, Selection} |
58529 | 20 |
import org.gjt.sp.jedit.syntax.TokenMarker |
63421 | 21 |
import org.gjt.sp.jedit.indent.IndentRule |
53293
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
22 |
import org.gjt.sp.jedit.gui.{DockableWindowManager, CompleteWord} |
61024
7b7f01afab71
avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents:
60890
diff
changeset
|
23 |
import org.jedit.options.CombinedOptions |
50183 | 24 |
|
25 |
||
50208 | 26 |
object Isabelle |
50183 | 27 |
{ |
53274
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
28 |
/* editor modes */ |
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
29 |
|
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
30 |
val modes = |
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
31 |
List( |
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
32 |
"isabelle", // theory source |
55500 | 33 |
"isabelle-ml", // ML source |
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
34 |
"isabelle-news", // NEWS |
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
35 |
"isabelle-options", // etc/options |
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
36 |
"isabelle-output", // pretty text area output |
56277
c4f75e733812
separate "sml" mode, suppress old "ml" mode altogether;
wenzelm
parents:
56170
diff
changeset
|
37 |
"isabelle-root", // session ROOT |
c4f75e733812
separate "sml" mode, suppress old "ml" mode altogether;
wenzelm
parents:
56170
diff
changeset
|
38 |
"sml") // Standard ML (not Isabelle/ML) |
53274
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
39 |
|
67004
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
40 |
private val ml_syntax: Outer_Syntax = |
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
41 |
Outer_Syntax.empty.no_tokens. |
55749 | 42 |
set_language_context(Completion.Language_Context.ML_outer) |
55616 | 43 |
|
67004
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
44 |
private val sml_syntax: Outer_Syntax = |
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
45 |
Outer_Syntax.empty.no_tokens. |
56278
2576d3a40ed6
separate tokenization and language context for SML: no symbols, no antiquotes;
wenzelm
parents:
56277
diff
changeset
|
46 |
set_language_context(Completion.Language_Context.SML_outer) |
2576d3a40ed6
separate tokenization and language context for SML: no symbols, no antiquotes;
wenzelm
parents:
56277
diff
changeset
|
47 |
|
67004
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
48 |
private val news_syntax: Outer_Syntax = |
af72fa58f71b
clarified lazy Completion within Outer_Syntax: measurable speedup of Sessions.deps;
wenzelm
parents:
66984
diff
changeset
|
49 |
Outer_Syntax.empty.no_tokens |
53276 | 50 |
|
59076
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
51 |
def mode_syntax(mode: String): Option[Outer_Syntax] = |
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
52 |
mode match { |
66720 | 53 |
case "isabelle" => Some(PIDE.resources.session_base.overall_syntax) |
53274
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
54 |
case "isabelle-options" => Some(Options.options_syntax) |
62631 | 55 |
case "isabelle-root" => Some(Sessions.root_syntax) |
55616 | 56 |
case "isabelle-ml" => Some(ml_syntax) |
57 |
case "isabelle-news" => Some(news_syntax) |
|
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
58 |
case "isabelle-output" => None |
56278
2576d3a40ed6
separate tokenization and language context for SML: no symbols, no antiquotes;
wenzelm
parents:
56277
diff
changeset
|
59 |
case "sml" => Some(sml_syntax) |
53274
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
60 |
case _ => None |
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
61 |
} |
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
62 |
|
59074 | 63 |
def buffer_syntax(buffer: JEditBuffer): Option[Outer_Syntax] = |
63868 | 64 |
if (buffer == null) None |
65 |
else |
|
64813 | 66 |
(JEdit_Lib.buffer_mode(buffer), Document_Model.get(buffer)) match { |
63868 | 67 |
case ("isabelle", Some(model)) => |
68 |
Some(PIDE.session.recent_syntax(model.node_name)) |
|
69 |
case (mode, _) => mode_syntax(mode) |
|
70 |
} |
|
59074 | 71 |
|
53274
1760c01f1c78
maintain Completion_Popup.Text_Area as client property like Document_View;
wenzelm
parents:
53272
diff
changeset
|
72 |
|
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
73 |
/* token markers */ |
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
74 |
|
59076
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
75 |
private val mode_markers: Map[String, TokenMarker] = |
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
76 |
Map(modes.map(mode => (mode, new Token_Markup.Marker(mode, None))): _*) + |
66120 | 77 |
("bibtex" -> new JEdit_Bibtex.Token_Marker) |
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
78 |
|
59076
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
79 |
def mode_token_marker(mode: String): Option[TokenMarker] = mode_markers.get(mode) |
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
80 |
|
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
81 |
def buffer_token_marker(buffer: Buffer): Option[TokenMarker] = |
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
82 |
{ |
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
83 |
val mode = JEdit_Lib.buffer_mode(buffer) |
60274
c2837a39da01
more conservative Document_Model.init: avoid Document.Node.Clear due to change of token marker (e.g. due to change of jEdit mode properties);
wenzelm
parents:
60074
diff
changeset
|
84 |
if (mode == "isabelle") Some(new Token_Markup.Marker(mode, Some(buffer))) |
c2837a39da01
more conservative Document_Model.init: avoid Document.Node.Clear due to change of token marker (e.g. due to change of jEdit mode properties);
wenzelm
parents:
60074
diff
changeset
|
85 |
else mode_token_marker(mode) |
59076
65babcd8b0e6
clarified token marker / syntax for mode vs. buffer;
wenzelm
parents:
59075
diff
changeset
|
86 |
} |
53277
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
87 |
|
6aa348237973
more uniform configuration of editor modes and token markers;
wenzelm
parents:
53276
diff
changeset
|
88 |
|
63422 | 89 |
/* text structure */ |
63421 | 90 |
|
63422 | 91 |
def indent_rule(mode: String): Option[IndentRule] = |
63444 | 92 |
mode match { |
93 |
case "isabelle" | "isabelle-options" | "isabelle-root" => |
|
94 |
Some(Text_Structure.Indent_Rule) |
|
95 |
case _ => None |
|
96 |
} |
|
63421 | 97 |
|
63422 | 98 |
def structure_matchers(mode: String): List[StructureMatcher] = |
99 |
if (mode == "isabelle") List(Text_Structure.Matcher) else Nil |
|
58748 | 100 |
|
101 |
||
50208 | 102 |
/* dockable windows */ |
103 |
||
104 |
private def wm(view: View): DockableWindowManager = view.getDockableWindowManager |
|
105 |
||
60749 | 106 |
def debugger_dockable(view: View): Option[Debugger_Dockable] = |
107 |
wm(view).getDockableWindow("isabelle-debugger") match { |
|
108 |
case dockable: Debugger_Dockable => Some(dockable) |
|
109 |
case _ => None |
|
110 |
} |
|
111 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
112 |
def documentation_dockable(view: View): Option[Documentation_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
113 |
wm(view).getDockableWindow("isabelle-documentation") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
114 |
case dockable: Documentation_Dockable => Some(dockable) |
50208 | 115 |
case _ => None |
116 |
} |
|
117 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
118 |
def monitor_dockable(view: View): Option[Monitor_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
119 |
wm(view).getDockableWindow("isabelle-monitor") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
120 |
case dockable: Monitor_Dockable => Some(dockable) |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
121 |
case _ => None |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
122 |
} |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
123 |
|
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
124 |
def output_dockable(view: View): Option[Output_Dockable] = |
50208 | 125 |
wm(view).getDockableWindow("isabelle-output") match { |
126 |
case dockable: Output_Dockable => Some(dockable) |
|
127 |
case _ => None |
|
128 |
} |
|
129 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
130 |
def protocol_dockable(view: View): Option[Protocol_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
131 |
wm(view).getDockableWindow("isabelle-protocol") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
132 |
case dockable: Protocol_Dockable => Some(dockable) |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
133 |
case _ => None |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
134 |
} |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
135 |
|
56879
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
136 |
def query_dockable(view: View): Option[Query_Dockable] = |
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
137 |
wm(view).getDockableWindow("isabelle-query") match { |
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
138 |
case dockable: Query_Dockable => Some(dockable) |
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
139 |
case _ => None |
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
140 |
} |
ee2b61f37ad9
renamed "Find" to "Query", with more general operations;
wenzelm
parents:
56662
diff
changeset
|
141 |
|
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
142 |
def raw_output_dockable(view: View): Option[Raw_Output_Dockable] = |
50208 | 143 |
wm(view).getDockableWindow("isabelle-raw-output") match { |
144 |
case dockable: Raw_Output_Dockable => Some(dockable) |
|
145 |
case _ => None |
|
146 |
} |
|
147 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
148 |
def simplifier_trace_dockable(view: View): Option[Simplifier_Trace_Dockable] = |
55557 | 149 |
wm(view).getDockableWindow("isabelle-simplifier-trace") match { |
55316
885500f4aa6a
interactive simplifier trace: new panel in Isabelle/jEdit to inspect and modify simplification state
Lars Hupel <lars.hupel@mytum.de>
parents:
54640
diff
changeset
|
150 |
case dockable: Simplifier_Trace_Dockable => Some(dockable) |
885500f4aa6a
interactive simplifier trace: new panel in Isabelle/jEdit to inspect and modify simplification state
Lars Hupel <lars.hupel@mytum.de>
parents:
54640
diff
changeset
|
151 |
case _ => None |
885500f4aa6a
interactive simplifier trace: new panel in Isabelle/jEdit to inspect and modify simplification state
Lars Hupel <lars.hupel@mytum.de>
parents:
54640
diff
changeset
|
152 |
} |
885500f4aa6a
interactive simplifier trace: new panel in Isabelle/jEdit to inspect and modify simplification state
Lars Hupel <lars.hupel@mytum.de>
parents:
54640
diff
changeset
|
153 |
|
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
154 |
def sledgehammer_dockable(view: View): Option[Sledgehammer_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
155 |
wm(view).getDockableWindow("isabelle-sledgehammer") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
156 |
case dockable: Sledgehammer_Dockable => Some(dockable) |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
157 |
case _ => None |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
158 |
} |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
159 |
|
61208 | 160 |
def state_dockable(view: View): Option[State_Dockable] = |
161 |
wm(view).getDockableWindow("isabelle-state") match { |
|
162 |
case dockable: State_Dockable => Some(dockable) |
|
163 |
case _ => None |
|
164 |
} |
|
165 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
166 |
def symbols_dockable(view: View): Option[Symbols_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
167 |
wm(view).getDockableWindow("isabelle-symbols") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
168 |
case dockable: Symbols_Dockable => Some(dockable) |
50208 | 169 |
case _ => None |
170 |
} |
|
171 |
||
55558
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
172 |
def syslog_dockable(view: View): Option[Syslog_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
173 |
wm(view).getDockableWindow("isabelle-syslog") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
174 |
case dockable: Syslog_Dockable => Some(dockable) |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
175 |
case _ => None |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
176 |
} |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
177 |
|
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
178 |
def theories_dockable(view: View): Option[Theories_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
179 |
wm(view).getDockableWindow("isabelle-theories") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
180 |
case dockable: Theories_Dockable => Some(dockable) |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
181 |
case _ => None |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
182 |
} |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
183 |
|
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
184 |
def timing_dockable(view: View): Option[Timing_Dockable] = |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
185 |
wm(view).getDockableWindow("isabelle-timing") match { |
298274c970b6
more uniform treatment of dockables and their standard actions;
wenzelm
parents:
55557
diff
changeset
|
186 |
case dockable: Timing_Dockable => Some(dockable) |
50433
9131dadb2bf7
basic monitor panel, using the powerful jfreechart library;
wenzelm
parents:
50341
diff
changeset
|
187 |
case _ => None |
9131dadb2bf7
basic monitor panel, using the powerful jfreechart library;
wenzelm
parents:
50341
diff
changeset
|
188 |
} |
9131dadb2bf7
basic monitor panel, using the powerful jfreechart library;
wenzelm
parents:
50341
diff
changeset
|
189 |
|
50208 | 190 |
|
52815
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
191 |
/* continuous checking */ |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
192 |
|
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
193 |
private val CONTINUOUS_CHECKING = "editor_continuous_checking" |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
194 |
|
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
195 |
def continuous_checking: Boolean = PIDE.options.bool(CONTINUOUS_CHECKING) |
60074
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
196 |
def continuous_checking_=(b: Boolean): Unit = |
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
197 |
GUI_Thread.require { |
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
198 |
if (continuous_checking != b) { |
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
199 |
PIDE.options.bool(CONTINUOUS_CHECKING) = b |
61725 | 200 |
PIDE.session.update_options(PIDE.options.value) |
60074
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
201 |
} |
52815
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
202 |
} |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
203 |
|
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
204 |
def set_continuous_checking() { continuous_checking = true } |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
205 |
def reset_continuous_checking() { continuous_checking = false } |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
206 |
def toggle_continuous_checking() { continuous_checking = !continuous_checking } |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
207 |
|
53715 | 208 |
class Continuous_Checking extends CheckBox("Continuous checking") |
209 |
{ |
|
210 |
tooltip = "Continuous checking of proof document (visible and required parts)" |
|
211 |
reactions += { case ButtonClicked(_) => continuous_checking = selected } |
|
212 |
def load() { selected = continuous_checking } |
|
213 |
load() |
|
214 |
} |
|
215 |
||
52815
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
216 |
|
61211 | 217 |
/* update state */ |
218 |
||
219 |
def update_state(view: View): Unit = |
|
61802
1d81de0bddc4
more thorough update request: semantic state of command may have changed elsewise;
wenzelm
parents:
61725
diff
changeset
|
220 |
state_dockable(view).foreach(_.update_request()) |
61211 | 221 |
|
222 |
||
60074
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
223 |
/* ML statistics */ |
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
224 |
|
60843 | 225 |
class ML_Stats extends |
226 |
JEdit_Options.Check_Box("ML_statistics", "ML statistics", "Enable ML runtime system statistics") |
|
60074
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
227 |
|
38a64cc17403
GUI controls for ML_statistics, for more digestible protocol dump;
wenzelm
parents:
59077
diff
changeset
|
228 |
|
52815
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
229 |
/* required document nodes */ |
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
230 |
|
64817 | 231 |
def set_node_required(view: View) { Document_Model.view_node_required(view, set = true) } |
232 |
def reset_node_required(view: View) { Document_Model.view_node_required(view, set = false) } |
|
233 |
def toggle_node_required(view: View) { Document_Model.view_node_required(view, toggle = true) } |
|
52815
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
234 |
|
eaad5fe7bb1b
actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents:
51533
diff
changeset
|
235 |
|
50198
0c7b351a6871
added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents:
50187
diff
changeset
|
236 |
/* font size */ |
0c7b351a6871
added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents:
50187
diff
changeset
|
237 |
|
55827 | 238 |
def reset_font_size() { |
239 |
Font_Info.main_change.reset(PIDE.options.int("jedit_reset_font_size").toFloat) |
|
55823
0331b6d2ab0c
font size change with delay, to avoid GUI lagging behind user input;
wenzelm
parents:
55749
diff
changeset
|
240 |
} |
55827 | 241 |
def increase_font_size() { Font_Info.main_change.step(1) } |
242 |
def decrease_font_size() { Font_Info.main_change.step(-1) } |
|
50198
0c7b351a6871
added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents:
50187
diff
changeset
|
243 |
|
0c7b351a6871
added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents:
50187
diff
changeset
|
244 |
|
53497 | 245 |
/* structured edits */ |
50341
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
246 |
|
66180 | 247 |
def indent_enabled(buffer: JEditBuffer, option: String): Boolean = |
248 |
indent_rule(JEdit_Lib.buffer_mode(buffer)).isDefined && |
|
249 |
buffer.getStringProperty("autoIndent") == "full" && |
|
250 |
PIDE.options.bool(option) |
|
251 |
||
252 |
def indent_input(text_area: TextArea) |
|
253 |
{ |
|
254 |
val buffer = text_area.getBuffer |
|
255 |
val line = text_area.getCaretLine |
|
256 |
val caret = text_area.getCaretPosition |
|
257 |
||
258 |
if (text_area.isEditable && indent_enabled(buffer, "jedit_indent_input")) { |
|
259 |
buffer_syntax(buffer) match { |
|
66183 | 260 |
case Some(syntax) => |
261 |
val nav = new Text_Structure.Navigator(syntax, buffer, true) |
|
66180 | 262 |
nav.iterator(line, 1).toStream.headOption match { |
263 |
case Some(Text.Info(range, tok)) |
|
264 |
if range.stop == caret && syntax.keywords.is_indent_command(tok) => |
|
265 |
buffer.indentLine(line, true) |
|
266 |
case _ => |
|
267 |
} |
|
66183 | 268 |
case None => |
66180 | 269 |
} |
270 |
} |
|
271 |
} |
|
272 |
||
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
273 |
def newline(text_area: TextArea) |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
274 |
{ |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
275 |
if (!text_area.isEditable()) text_area.getToolkit().beep() |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
276 |
else { |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
277 |
val buffer = text_area.getBuffer |
66182 | 278 |
val line = text_area.getCaretLine |
279 |
val caret = text_area.getCaretPosition |
|
280 |
||
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
281 |
def nl { text_area.userInput('\n') } |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
282 |
|
66180 | 283 |
if (indent_enabled(buffer, "jedit_indent_newline")) { |
284 |
buffer_syntax(buffer) match { |
|
66182 | 285 |
case Some(syntax) => |
63484 | 286 |
val keywords = syntax.keywords |
287 |
||
66173 | 288 |
val (toks1, toks2) = Text_Structure.split_line_content(buffer, keywords, line, caret) |
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
289 |
|
66174 | 290 |
if (toks1.isEmpty) buffer.removeTrailingWhiteSpace(Array(line)) |
291 |
else if (keywords.is_indent_command(toks1.head)) buffer.indentLine(line, true) |
|
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
292 |
|
66469
a6ec0172211a
avoid compound edit: it causes confusion about the context of the last line, e.g. final "end";
wenzelm
parents:
66183
diff
changeset
|
293 |
if (toks2.isEmpty || keywords.is_indent_command(toks2.head)) { |
a6ec0172211a
avoid compound edit: it causes confusion about the context of the last line, e.g. final "end";
wenzelm
parents:
66183
diff
changeset
|
294 |
text_area.setSelectedText("\n") |
a6ec0172211a
avoid compound edit: it causes confusion about the context of the last line, e.g. final "end";
wenzelm
parents:
66183
diff
changeset
|
295 |
if (!buffer.indentLine(line + 1, true)) text_area.goToStartOfWhiteSpace(false) |
a6ec0172211a
avoid compound edit: it causes confusion about the context of the last line, e.g. final "end";
wenzelm
parents:
66183
diff
changeset
|
296 |
} |
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
297 |
else nl |
66182 | 298 |
case None => nl |
63455
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
299 |
} |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
300 |
} |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
301 |
else nl |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
302 |
} |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
303 |
} |
019856db2bb6
added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents:
63444
diff
changeset
|
304 |
|
50341
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
305 |
def insert_line_padding(text_area: JEditTextArea, text: String) |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
306 |
{ |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
307 |
val buffer = text_area.getBuffer |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
308 |
JEdit_Lib.buffer_edit(buffer) { |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
309 |
val text1 = |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
310 |
if (text_area.getSelectionCount == 0) { |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
311 |
def pad(range: Text.Range): String = |
67014 | 312 |
if (JEdit_Lib.get_text(buffer, range) == Some("\n")) "" else "\n" |
50341
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
313 |
|
56592
5157f7615e99
prefer direct caret_range for update_dictionary actions, which usually happen outside the flow of editing;
wenzelm
parents:
56587
diff
changeset
|
314 |
val caret = JEdit_Lib.caret_range(text_area) |
50341
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
315 |
val before_caret = JEdit_Lib.point_range(buffer, caret.start - 1) |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
316 |
pad(before_caret) + text + pad(caret) |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
317 |
} |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
318 |
else text |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
319 |
text_area.setSelectedText(text1) |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
320 |
} |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
321 |
} |
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
322 |
|
53497 | 323 |
def edit_command( |
324 |
snapshot: Document.Snapshot, |
|
63508 | 325 |
text_area: TextArea, |
53497 | 326 |
padding: Boolean, |
54640
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
327 |
id: Document_ID.Generic, |
63508 | 328 |
text: String) |
53497 | 329 |
{ |
63508 | 330 |
val buffer = text_area.getBuffer |
331 |
if (!snapshot.is_outdated && text != "") { |
|
64813 | 332 |
(snapshot.find_command(id), Document_Model.get(buffer)) match { |
57861
287e3b1298b3
restrict edit_command (for sendback) to current node -- no attempt to goto target buffer first, which might not be loaded;
wenzelm
parents:
57627
diff
changeset
|
333 |
case (Some((node, command)), Some(model)) if command.node_name == model.node_name => |
54640
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
334 |
node.command_start(command) match { |
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
335 |
case Some(start) => |
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
336 |
JEdit_Lib.buffer_edit(buffer) { |
68728 | 337 |
val range = command.core_range + start |
63508 | 338 |
JEdit_Lib.buffer_edit(buffer) { |
339 |
if (padding) { |
|
340 |
text_area.moveCaretPosition(start + range.length) |
|
64456
f630e9385d7e
more accurate start_line: avoid changing the original command (e.g. 'try', 'sledgehammer');
wenzelm
parents:
63868
diff
changeset
|
341 |
val start_line = text_area.getCaretLine + 1 |
63508 | 342 |
text_area.setSelectedText("\n" + text) |
343 |
val end_line = text_area.getCaretLine |
|
344 |
buffer.indentLines(start_line, end_line) |
|
345 |
} |
|
346 |
else { |
|
347 |
buffer.remove(start, range.length) |
|
348 |
text_area.moveCaretPosition(start) |
|
349 |
text_area.setSelectedText(text) |
|
350 |
} |
|
54640
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
351 |
} |
53497 | 352 |
} |
54640
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
353 |
case None => |
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
354 |
} |
57861
287e3b1298b3
restrict edit_command (for sendback) to current node -- no attempt to goto target buffer first, which might not be loaded;
wenzelm
parents:
57627
diff
changeset
|
355 |
case _ => |
54640
bbd2fa353809
back to Status.FINISHED and immediate remove_overlay (reverting 6e69f9ca8f1c), which is important to avoid restart of print function after edits + re-assignment of located command;
wenzelm
parents:
53843
diff
changeset
|
356 |
} |
53497 | 357 |
} |
358 |
} |
|
359 |
||
50341
0c65a7cfc0f3
provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents:
50299
diff
changeset
|
360 |
|
63236 | 361 |
/* selection */ |
362 |
||
363 |
def select_entity(text_area: JEditTextArea) |
|
364 |
{ |
|
71495 | 365 |
for (doc_view <- Document_View.get(text_area)) { |
366 |
val rendering = doc_view.get_rendering() |
|
63236 | 367 |
val caret_range = JEdit_Lib.caret_range(text_area) |
368 |
val buffer_range = JEdit_Lib.buffer_range(text_area.getBuffer) |
|
369 |
val active_focus = rendering.caret_focus_ranges(caret_range, buffer_range) |
|
370 |
if (active_focus.nonEmpty) { |
|
371 |
text_area.selectNone() |
|
372 |
for (r <- active_focus) |
|
373 |
text_area.addToSelection(new Selection.Range(r.start, r.stop)) |
|
374 |
} |
|
375 |
} |
|
376 |
} |
|
377 |
||
378 |
||
53293
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
379 |
/* completion */ |
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
380 |
|
56586 | 381 |
def complete(view: View, word_only: Boolean) |
53293
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
382 |
{ |
57424
966b12f636b9
removed slightly odd fall-back on complete-word (NB: connection to default menu action is unclear);
wenzelm
parents:
56879
diff
changeset
|
383 |
Completion_Popup.Text_Area.action(view.getTextArea, word_only) |
53293
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
384 |
} |
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
385 |
|
fd27b8f5a479
added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents:
53281
diff
changeset
|
386 |
|
50183 | 387 |
/* control styles */ |
388 |
||
389 |
def control_sub(text_area: JEditTextArea) |
|
65259 | 390 |
{ Syntax_Style.edit_control_style(text_area, Symbol.sub) } |
50183 | 391 |
|
392 |
def control_sup(text_area: JEditTextArea) |
|
65259 | 393 |
{ Syntax_Style.edit_control_style(text_area, Symbol.sup) } |
50183 | 394 |
|
395 |
def control_bold(text_area: JEditTextArea) |
|
65259 | 396 |
{ Syntax_Style.edit_control_style(text_area, Symbol.bold) } |
50183 | 397 |
|
61483 | 398 |
def control_emph(text_area: JEditTextArea) |
65259 | 399 |
{ Syntax_Style.edit_control_style(text_area, Symbol.emph) } |
61483 | 400 |
|
50183 | 401 |
def control_reset(text_area: JEditTextArea) |
65259 | 402 |
{ Syntax_Style.edit_control_style(text_area, "") } |
50183 | 403 |
|
404 |
||
405 |
/* block styles */ |
|
406 |
||
407 |
private def enclose_input(text_area: JEditTextArea, s1: String, s2: String) |
|
408 |
{ |
|
409 |
s1.foreach(text_area.userInput(_)) |
|
410 |
s2.foreach(text_area.userInput(_)) |
|
411 |
s2.foreach(_ => text_area.goToPrevCharacter(false)) |
|
412 |
} |
|
413 |
||
414 |
def input_bsub(text_area: JEditTextArea) |
|
415 |
{ enclose_input(text_area, Symbol.bsub_decoded, Symbol.esub_decoded) } |
|
416 |
||
417 |
def input_bsup(text_area: JEditTextArea) |
|
418 |
{ enclose_input(text_area, Symbol.bsup_decoded, Symbol.esup_decoded) } |
|
56574
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
419 |
|
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
420 |
|
67132 | 421 |
/* antiquoted cartouche */ |
422 |
||
423 |
def antiquoted_cartouche(text_area: TextArea) |
|
424 |
{ |
|
425 |
val buffer = text_area.getBuffer |
|
426 |
for { |
|
427 |
doc_view <- Document_View.get(text_area) |
|
428 |
rendering = doc_view.get_rendering() |
|
429 |
caret_range = JEdit_Lib.caret_range(text_area) |
|
430 |
antiq_range <- rendering.antiquoted(caret_range) |
|
431 |
antiq_text <- JEdit_Lib.get_text(buffer, antiq_range) |
|
432 |
body_text <- Antiquote.read_antiq_body(antiq_text) |
|
433 |
(name, arg) <- Token.read_antiq_arg(Keyword.Keywords.empty, body_text) |
|
434 |
if Symbol.is_ascii_identifier(name) |
|
435 |
} { |
|
436 |
val op_text = |
|
437 |
Isabelle_Encoding.perhaps_decode(buffer, |
|
438 |
Symbol.control_prefix + name + Symbol.control_suffix) |
|
439 |
val arg_text = |
|
440 |
if (arg.isEmpty) "" |
|
441 |
else if (Isabelle_Encoding.is_active(buffer)) Symbol.cartouche_decoded(arg.get) |
|
442 |
else Symbol.cartouche(arg.get) |
|
443 |
||
444 |
buffer.remove(antiq_range.start, antiq_range.length) |
|
445 |
text_area.moveCaretPosition(antiq_range.start) |
|
67148
d24dcac5eb4c
more robust, e.g. when Sidekick produces multi-selection;
wenzelm
parents:
67132
diff
changeset
|
446 |
text_area.selectNone |
67132 | 447 |
text_area.setSelectedText(op_text + arg_text) |
448 |
} |
|
449 |
} |
|
450 |
||
451 |
||
56574
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
452 |
/* spell-checker dictionary */ |
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
453 |
|
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
454 |
def update_dictionary(text_area: JEditTextArea, include: Boolean, permanent: Boolean) |
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
455 |
{ |
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
456 |
for { |
65239
509a9b0ad02e
avoid global variables with implicit initialization;
wenzelm
parents:
65224
diff
changeset
|
457 |
spell_checker <- PIDE.plugin.spell_checker.get |
64882 | 458 |
doc_view <- Document_View.get(text_area) |
56576 | 459 |
rendering = doc_view.get_rendering() |
56592
5157f7615e99
prefer direct caret_range for update_dictionary actions, which usually happen outside the flow of editing;
wenzelm
parents:
56587
diff
changeset
|
460 |
range = JEdit_Lib.caret_range(text_area) |
66116 | 461 |
Text.Info(_, word) <- Spell_Checker.current_word(rendering, range) |
56575 | 462 |
} { |
463 |
spell_checker.update(word, include, permanent) |
|
464 |
JEdit_Lib.jedit_views().foreach(_.repaint()) |
|
465 |
} |
|
56574
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
466 |
} |
2b38472a4695
some actions to maintain spell-checker dictionary;
wenzelm
parents:
56394
diff
changeset
|
467 |
|
56578 | 468 |
def reset_dictionary() |
56575 | 469 |
{ |
65239
509a9b0ad02e
avoid global variables with implicit initialization;
wenzelm
parents:
65224
diff
changeset
|
470 |
for (spell_checker <- PIDE.plugin.spell_checker.get) |
56575 | 471 |
{ |
472 |
spell_checker.reset() |
|
473 |
JEdit_Lib.jedit_views().foreach(_.repaint()) |
|
474 |
} |
|
475 |
} |
|
57627
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
476 |
|
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
477 |
|
60878
1f0d2bbcf38b
added action to toggle breakpoints (on editor side);
wenzelm
parents:
60843
diff
changeset
|
478 |
/* debugger */ |
1f0d2bbcf38b
added action to toggle breakpoints (on editor side);
wenzelm
parents:
60843
diff
changeset
|
479 |
|
60890 | 480 |
def toggle_breakpoint(text_area: JEditTextArea): Unit = |
65224 | 481 |
{ |
482 |
GUI_Thread.require {} |
|
483 |
||
65247 | 484 |
if (PIDE.session.debugger.is_active()) { |
65224 | 485 |
Debugger_Dockable.get_breakpoint(text_area, text_area.getCaretPosition) match { |
486 |
case Some((command, breakpoint)) => |
|
65247 | 487 |
PIDE.session.debugger.toggle_breakpoint(command, breakpoint) |
65224 | 488 |
jEdit.propertiesChanged() |
489 |
case None => |
|
490 |
} |
|
60890 | 491 |
} |
65224 | 492 |
} |
60878
1f0d2bbcf38b
added action to toggle breakpoints (on editor side);
wenzelm
parents:
60843
diff
changeset
|
493 |
|
1f0d2bbcf38b
added action to toggle breakpoints (on editor side);
wenzelm
parents:
60843
diff
changeset
|
494 |
|
57627
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
495 |
/* plugin options */ |
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
496 |
|
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
497 |
def plugin_options(frame: Frame) |
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
498 |
{ |
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
499 |
GUI_Thread.require {} |
61024
7b7f01afab71
avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents:
60890
diff
changeset
|
500 |
jEdit.setProperty("Plugin Options.last", "isabelle-general") |
7b7f01afab71
avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents:
60890
diff
changeset
|
501 |
new CombinedOptions(frame, 1) |
57627
65fc7ae1bf66
added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents:
57612
diff
changeset
|
502 |
} |
65240 | 503 |
|
504 |
||
505 |
/* popups */ |
|
506 |
||
507 |
def dismissed_popups(view: View): Boolean = |
|
508 |
{ |
|
509 |
var dismissed = false |
|
510 |
||
511 |
JEdit_Lib.jedit_text_areas(view).foreach(text_area => |
|
512 |
if (Completion_Popup.Text_Area.dismissed(text_area)) dismissed = true) |
|
513 |
||
514 |
if (Pretty_Tooltip.dismissed_all()) dismissed = true |
|
515 |
||
516 |
dismissed |
|
517 |
} |
|
71497 | 518 |
|
519 |
||
520 |
/* tooltips */ |
|
521 |
||
522 |
def show_tooltip(view: View, control: Boolean) |
|
523 |
{ |
|
524 |
GUI_Thread.require {} |
|
525 |
||
526 |
val text_area = view.getTextArea |
|
527 |
val painter = text_area.getPainter |
|
528 |
val caret_range = JEdit_Lib.caret_range(text_area) |
|
529 |
for { |
|
530 |
doc_view <- Document_View.get(text_area) |
|
531 |
rendering = doc_view.get_rendering() |
|
532 |
tip <- rendering.tooltip(caret_range, control) |
|
533 |
loc0 <- Option(text_area.offsetToXY(caret_range.start)) |
|
534 |
} { |
|
535 |
val loc = new Point(loc0.x, loc0.y + painter.getLineHeight / 2) |
|
536 |
val results = rendering.snapshot.command_results(tip.range) |
|
537 |
Pretty_Tooltip(view, painter, loc, rendering, results, tip) |
|
538 |
} |
|
539 |
} |
|
71499 | 540 |
|
541 |
||
542 |
/* error navigation */ |
|
543 |
||
544 |
private def goto_error( |
|
545 |
view: View, range: Text.Range, which: String = "")(get: List[Text.Markup] => Option[Text.Markup]) |
|
546 |
{ |
|
547 |
GUI_Thread.require {} |
|
548 |
||
549 |
val text_area = view.getTextArea |
|
550 |
for (doc_view <- Document_View.get(text_area)) { |
|
551 |
val rendering = doc_view.get_rendering() |
|
552 |
get(rendering.errors(range)) match { |
|
553 |
case Some(err) => |
|
554 |
PIDE.editor.goto_buffer(false, view, view.getBuffer, err.range.start) |
|
555 |
case None => |
|
556 |
view.getStatus.setMessageAndClear("No " + which + "error in current document snapshot") |
|
557 |
} |
|
558 |
} |
|
559 |
} |
|
560 |
||
561 |
def goto_first_error(view: View): Unit = |
|
562 |
goto_error(view, JEdit_Lib.buffer_range(view.getBuffer))(_.headOption) |
|
563 |
||
564 |
def goto_last_error(view: View): Unit = |
|
565 |
goto_error(view, JEdit_Lib.buffer_range(view.getBuffer))(_.lastOption) |
|
566 |
||
567 |
def goto_prev_error(view: View): Unit = |
|
568 |
goto_error(view, JEdit_Lib.buffer_range_to_caret(view.getTextArea), which = "previous ")( |
|
569 |
list => |
|
570 |
list.reverse match { |
|
571 |
case _ :: err :: _ => Some(err) |
|
572 |
case _ => None |
|
573 |
}) |
|
574 |
||
575 |
def goto_next_error(view: View): Unit = |
|
576 |
goto_error(view, JEdit_Lib.buffer_range_from_caret(view.getTextArea), which = "next ")( |
|
577 |
{ |
|
578 |
case _ :: err :: _ => Some(err) |
|
579 |
case _ => None |
|
580 |
}) |
|
50183 | 581 |
} |