src/Tools/jEdit/src/isabelle.scala
author wenzelm
Fri, 23 Jun 2017 22:07:12 +0200
changeset 66182 1a4b6ae5e72b
parent 66180 201d42f67bba
child 66183 c67933ea9234
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50208
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
     1
/*  Title:      Tools/jEdit/src/isabelle.scala
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     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
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     5
*/
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     6
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     7
package isabelle.jedit
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     8
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
     9
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
    10
import isabelle._
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
    11
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
    12
import java.awt.Frame
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
    13
53715
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
    14
import scala.swing.CheckBox
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
    15
import scala.swing.event.ButtonClicked
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
    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
7836d927ffca tuned signature;
wenzelm
parents: 58804
diff changeset
    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
cd4439d8799c support for bibtex token markup;
wenzelm
parents: 57861
diff changeset
    20
import org.gjt.sp.jedit.syntax.TokenMarker
63421
3bf02e7fa8a3 basic setup for indentation;
wenzelm
parents: 63236
diff changeset
    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
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
    24
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
    25
50208
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
    26
object Isabelle
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
    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
cdbbaa3074a8 isabelle-ml mode with separate token marker;
wenzelm
parents: 55316
diff changeset
    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
55616
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    40
  private lazy val ml_syntax: Outer_Syntax =
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    41
    Outer_Syntax.init().no_tokens.
55749
75a48dc4383e tuned signature;
wenzelm
parents: 55666
diff changeset
    42
      set_language_context(Completion.Language_Context.ML_outer)
55616
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    43
56278
2576d3a40ed6 separate tokenization and language context for SML: no symbols, no antiquotes;
wenzelm
parents: 56277
diff changeset
    44
  private lazy val sml_syntax: Outer_Syntax =
2576d3a40ed6 separate tokenization and language context for SML: no symbols, no antiquotes;
wenzelm
parents: 56277
diff changeset
    45
    Outer_Syntax.init().no_tokens.
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
55616
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    48
  private lazy val news_syntax: Outer_Syntax =
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    49
    Outer_Syntax.init().no_tokens
53276
cbed0aa0b0db syntax for isabelle-news with symbol completion;
wenzelm
parents: 53274
diff changeset
    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 {
65361
ecefb68dc21d tuned signature;
wenzelm
parents: 65259
diff changeset
    53
      case "isabelle" => Some(PIDE.resources.session_base.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
c39614ddb80b clarified modules;
wenzelm
parents: 62104
diff changeset
    55
      case "isabelle-root" => Some(Sessions.root_syntax)
55616
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    56
      case "isabelle-ml" => Some(ml_syntax)
25a7a998852a default completion context via outer syntax;
wenzelm
parents: 55558
diff changeset
    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
7836d927ffca tuned signature;
wenzelm
parents: 58804
diff changeset
    63
  def buffer_syntax(buffer: JEditBuffer): Option[Outer_Syntax] =
63868
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    64
    if (buffer == null) None
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    65
    else
64813
7283f41d05ab manage buffer models as explicit global state;
wenzelm
parents: 64665
diff changeset
    66
      (JEdit_Lib.buffer_mode(buffer), Document_Model.get(buffer)) match {
63868
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    67
        case ("isabelle", Some(model)) =>
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    68
          Some(PIDE.session.recent_syntax(model.node_name))
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    69
        case (mode, _) => mode_syntax(mode)
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    70
      }
59074
7836d927ffca tuned signature;
wenzelm
parents: 58804
diff changeset
    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
e03ff7e831cc clarified modules;
wenzelm
parents: 66116
diff changeset
    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
5cf8dd98a717 clarified modules;
wenzelm
parents: 63421
diff changeset
    89
  /* text structure */
63421
3bf02e7fa8a3 basic setup for indentation;
wenzelm
parents: 63236
diff changeset
    90
63422
5cf8dd98a717 clarified modules;
wenzelm
parents: 63421
diff changeset
    91
  def indent_rule(mode: String): Option[IndentRule] =
63444
8191c3e9f2d3 support more modes;
wenzelm
parents: 63422
diff changeset
    92
    mode match {
8191c3e9f2d3 support more modes;
wenzelm
parents: 63422
diff changeset
    93
      case "isabelle" | "isabelle-options" | "isabelle-root" =>
8191c3e9f2d3 support more modes;
wenzelm
parents: 63422
diff changeset
    94
        Some(Text_Structure.Indent_Rule)
8191c3e9f2d3 support more modes;
wenzelm
parents: 63422
diff changeset
    95
      case _ => None
8191c3e9f2d3 support more modes;
wenzelm
parents: 63422
diff changeset
    96
    }
63421
3bf02e7fa8a3 basic setup for indentation;
wenzelm
parents: 63236
diff changeset
    97
63422
5cf8dd98a717 clarified modules;
wenzelm
parents: 63421
diff changeset
    98
  def structure_matchers(mode: String): List[StructureMatcher] =
5cf8dd98a717 clarified modules;
wenzelm
parents: 63421
diff changeset
    99
    if (mode == "isabelle") List(Text_Structure.Matcher) else Nil
58748
8f92f17d8781 support for structure matching;
wenzelm
parents: 58546
diff changeset
   100
8f92f17d8781 support for structure matching;
wenzelm
parents: 58546
diff changeset
   101
50208
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   102
  /* dockable windows */
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   103
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   104
  private def wm(view: View): DockableWindowManager = view.getDockableWindowManager
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   105
60749
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   106
  def debugger_dockable(view: View): Option[Debugger_Dockable] =
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   107
    wm(view).getDockableWindow("isabelle-debugger") match {
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   108
      case dockable: Debugger_Dockable => Some(dockable)
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   109
      case _ => None
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   110
    }
f727b99faaf7 skeleton for interactive debugger;
wenzelm
parents: 60274
diff changeset
   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
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   115
      case _ => None
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   116
    }
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   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
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   125
    wm(view).getDockableWindow("isabelle-output") match {
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   126
      case dockable: Output_Dockable => Some(dockable)
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   127
      case _ => None
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   128
    }
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   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
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   143
    wm(view).getDockableWindow("isabelle-raw-output") match {
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   144
      case dockable: Raw_Output_Dockable => Some(dockable)
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   145
      case _ => None
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   146
    }
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   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
aa1adeca714b standardized action and panel names;
wenzelm
parents: 55500
diff changeset
   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
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   160
  def state_dockable(view: View): Option[State_Dockable] =
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   161
    wm(view).getDockableWindow("isabelle-state") match {
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   162
      case dockable: State_Dockable => Some(dockable)
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   163
      case _ => None
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   164
    }
19118f9b939d separate panel for proof state output;
wenzelm
parents: 61024
diff changeset
   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
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   169
      case _ => None
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   170
    }
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   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
1382ad6d4774 tuned signature;
wenzelm
parents: 50206
diff changeset
   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
1529c3eb6bac more thorough update of options;
wenzelm
parents: 61483
diff changeset
   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
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   208
  class Continuous_Checking extends CheckBox("Continuous checking")
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   209
  {
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   210
    tooltip = "Continuous checking of proof document (visible and required parts)"
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   211
    reactions += { case ButtonClicked(_) => continuous_checking = selected }
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   212
    def load() { selected = continuous_checking }
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   213
    load()
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   214
  }
68c664737d04 added option "jedit_auto_load";
wenzelm
parents: 53497
diff changeset
   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
8a5d5ca5d8bc added action "isabelle-update-state";
wenzelm
parents: 61208
diff changeset
   217
  /* update state */
8a5d5ca5d8bc added action "isabelle-update-state";
wenzelm
parents: 61208
diff changeset
   218
8a5d5ca5d8bc added action "isabelle-update-state";
wenzelm
parents: 61208
diff changeset
   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
8a5d5ca5d8bc added action "isabelle-update-state";
wenzelm
parents: 61208
diff changeset
   221
8a5d5ca5d8bc added action "isabelle-update-state";
wenzelm
parents: 61208
diff changeset
   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
9980f3bcdea2 tuned signature;
wenzelm
parents: 60749
diff changeset
   225
  class ML_Stats extends
9980f3bcdea2 tuned signature;
wenzelm
parents: 60749
diff changeset
   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
0bb6b582bb4f separate Buffer_Model vs. File_Model;
wenzelm
parents: 64813
diff changeset
   231
  def set_node_required(view: View) { Document_Model.view_node_required(view, set = true) }
0bb6b582bb4f separate Buffer_Model vs. File_Model;
wenzelm
parents: 64813
diff changeset
   232
  def reset_node_required(view: View) { Document_Model.view_node_required(view, set = false) }
0bb6b582bb4f separate Buffer_Model vs. File_Model;
wenzelm
parents: 64813
diff changeset
   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
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   238
  def reset_font_size() {
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   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
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   241
  def increase_font_size() { Font_Info.main_change.step(1) }
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   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
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   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
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   247
  def indent_enabled(buffer: JEditBuffer, option: String): Boolean =
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   248
    indent_rule(JEdit_Lib.buffer_mode(buffer)).isDefined &&
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   249
    buffer.getStringProperty("autoIndent") == "full" &&
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   250
    PIDE.options.bool(option)
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   251
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   252
  def indent_input(text_area: TextArea)
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   253
  {
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   254
    val buffer = text_area.getBuffer
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   255
    val line = text_area.getCaretLine
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   256
    val caret = text_area.getCaretPosition
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   257
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   258
    if (text_area.isEditable && indent_enabled(buffer, "jedit_indent_input")) {
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   259
      buffer_syntax(buffer) match {
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   260
        case Some(syntax) if buffer.isInstanceOf[Buffer] =>
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   261
          val nav = new Text_Structure.Navigator(syntax, buffer.asInstanceOf[Buffer], true)
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   262
          nav.iterator(line, 1).toStream.headOption match {
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   263
            case Some(Text.Info(range, tok))
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   264
            if range.stop == caret && syntax.keywords.is_indent_command(tok) =>
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   265
              buffer.indentLine(line, true)
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   266
            case _ =>
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   267
          }
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   268
        case _ =>
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   269
      }
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   270
    }
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   271
  }
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   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
wenzelm
parents: 66180
diff changeset
   278
      val line = text_area.getCaretLine
wenzelm
parents: 66180
diff changeset
   279
      val caret = text_area.getCaretPosition
wenzelm
parents: 66180
diff changeset
   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
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   283
      if (indent_enabled(buffer, "jedit_indent_newline")) {
201d42f67bba indentation of keywords after input;
wenzelm
parents: 66174
diff changeset
   284
        buffer_syntax(buffer) match {
66182
wenzelm
parents: 66180
diff changeset
   285
          case Some(syntax) =>
63484
2033a3960c36 auto indentation of quasi commands;
wenzelm
parents: 63477
diff changeset
   286
            val keywords = syntax.keywords
2033a3960c36 auto indentation of quasi commands;
wenzelm
parents: 63477
diff changeset
   287
66173
6c71a3af85a3 clarified modules;
wenzelm
parents: 66120
diff changeset
   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
8903653fc22e avoid trailing spaces;
wenzelm
parents: 66173
diff changeset
   290
            if (toks1.isEmpty) buffer.removeTrailingWhiteSpace(Array(line))
8903653fc22e avoid trailing spaces;
wenzelm
parents: 66173
diff changeset
   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
66173
6c71a3af85a3 clarified modules;
wenzelm
parents: 66120
diff changeset
   293
            if (toks2.isEmpty || keywords.is_indent_command(toks2.head))
63455
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   294
              JEdit_Lib.buffer_edit(buffer) {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   295
                text_area.setSelectedText("\n")
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   296
                if (!buffer.indentLine(line + 1, true)) text_area.goToStartOfWhiteSpace(false)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   297
              }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   298
            else nl
66182
wenzelm
parents: 66180
diff changeset
   299
          case None => nl
63455
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
      }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   302
      else nl
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
  }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   305
50341
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   306
  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
   307
  {
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   308
    val buffer = text_area.getBuffer
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   309
    JEdit_Lib.buffer_edit(buffer) {
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   310
      val text1 =
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   311
        if (text_area.getSelectionCount == 0) {
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   312
          def pad(range: Text.Range): String =
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   313
            if (JEdit_Lib.try_get_text(buffer, range) == Some("\n")) "" else "\n"
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   314
56592
5157f7615e99 prefer direct caret_range for update_dictionary actions, which usually happen outside the flow of editing;
wenzelm
parents: 56587
diff changeset
   315
          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
   316
          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
   317
          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
   318
        }
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   319
        else text
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   320
      text_area.setSelectedText(text1)
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
  }
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   323
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   324
  def edit_command(
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   325
    snapshot: Document.Snapshot,
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   326
    text_area: TextArea,
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   327
    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
   328
    id: Document_ID.Generic,
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   329
    text: String)
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   330
  {
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   331
    val buffer = text_area.getBuffer
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   332
    if (!snapshot.is_outdated && text != "") {
64813
7283f41d05ab manage buffer models as explicit global state;
wenzelm
parents: 64665
diff changeset
   333
      (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
   334
        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
   335
          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
   336
            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
   337
              JEdit_Lib.buffer_edit(buffer) {
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
   338
                val range = command.proper_range + start
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   339
                JEdit_Lib.buffer_edit(buffer) {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   340
                  if (padding) {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   341
                    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
   342
                    val start_line = text_area.getCaretLine + 1
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   343
                    text_area.setSelectedText("\n" + text)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   344
                    val end_line = text_area.getCaretLine
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   345
                    buffer.indentLines(start_line, end_line)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   346
                  }
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   347
                  else {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   348
                    buffer.remove(start, range.length)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   349
                    text_area.moveCaretPosition(start)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   350
                    text_area.setSelectedText(text)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   351
                  }
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
   352
                }
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   353
              }
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
   354
            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
   355
          }
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
   356
        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
   357
      }
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   358
    }
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   359
  }
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   360
50341
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   361
63236
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   362
  /* selection */
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   363
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   364
  def select_entity(text_area: JEditTextArea)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   365
  {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   366
    for {
64882
c3b42ac0cf81 tuned signature;
wenzelm
parents: 64854
diff changeset
   367
      doc_view <- Document_View.get(text_area)
63236
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   368
      rendering = doc_view.get_rendering()
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   369
    } {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   370
      val caret_range = JEdit_Lib.caret_range(text_area)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   371
      val buffer_range = JEdit_Lib.buffer_range(text_area.getBuffer)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   372
      val active_focus = rendering.caret_focus_ranges(caret_range, buffer_range)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   373
      if (active_focus.nonEmpty) {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   374
        text_area.selectNone()
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   375
        for (r <- active_focus)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   376
          text_area.addToSelection(new Selection.Range(r.start, r.stop))
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   377
      }
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   378
    }
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   379
  }
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   380
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   381
53293
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   382
  /* completion */
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   383
56586
5ef60881681d explicit menu action to complete word;
wenzelm
parents: 56578
diff changeset
   384
  def complete(view: View, word_only: Boolean)
53293
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   385
  {
57424
966b12f636b9 removed slightly odd fall-back on complete-word (NB: connection to default menu action is unclear);
wenzelm
parents: 56879
diff changeset
   386
    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
   387
  }
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   388
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   389
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   390
  /* control styles */
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   391
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   392
  def control_sub(text_area: JEditTextArea)
65259
41d12227d5dc clarified modules;
wenzelm
parents: 65247
diff changeset
   393
  { Syntax_Style.edit_control_style(text_area, Symbol.sub) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   394
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   395
  def control_sup(text_area: JEditTextArea)
65259
41d12227d5dc clarified modules;
wenzelm
parents: 65247
diff changeset
   396
  { Syntax_Style.edit_control_style(text_area, Symbol.sup) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   397
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   398
  def control_bold(text_area: JEditTextArea)
65259
41d12227d5dc clarified modules;
wenzelm
parents: 65247
diff changeset
   399
  { Syntax_Style.edit_control_style(text_area, Symbol.bold) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   400
61483
07c8d5d8acab added action "isabelle-emph";
wenzelm
parents: 61211
diff changeset
   401
  def control_emph(text_area: JEditTextArea)
65259
41d12227d5dc clarified modules;
wenzelm
parents: 65247
diff changeset
   402
  { Syntax_Style.edit_control_style(text_area, Symbol.emph) }
61483
07c8d5d8acab added action "isabelle-emph";
wenzelm
parents: 61211
diff changeset
   403
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   404
  def control_reset(text_area: JEditTextArea)
65259
41d12227d5dc clarified modules;
wenzelm
parents: 65247
diff changeset
   405
  { Syntax_Style.edit_control_style(text_area, "") }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   406
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   407
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   408
  /* block styles */
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   409
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   410
  private def enclose_input(text_area: JEditTextArea, s1: String, s2: String)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   411
  {
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   412
    s1.foreach(text_area.userInput(_))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   413
    s2.foreach(text_area.userInput(_))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   414
    s2.foreach(_ => text_area.goToPrevCharacter(false))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   415
  }
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   416
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   417
  def input_bsub(text_area: JEditTextArea)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   418
  { enclose_input(text_area, Symbol.bsub_decoded, Symbol.esub_decoded) }
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   419
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   420
  def input_bsup(text_area: JEditTextArea)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   421
  { enclose_input(text_area, Symbol.bsup_decoded, Symbol.esup_decoded) }
56574
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   422
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   423
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   424
  /* spell-checker dictionary */
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   425
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   426
  def update_dictionary(text_area: JEditTextArea, include: Boolean, permanent: Boolean)
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   427
  {
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   428
    for {
65239
509a9b0ad02e avoid global variables with implicit initialization;
wenzelm
parents: 65224
diff changeset
   429
      spell_checker <- PIDE.plugin.spell_checker.get
64882
c3b42ac0cf81 tuned signature;
wenzelm
parents: 64854
diff changeset
   430
      doc_view <- Document_View.get(text_area)
56576
86148ca3c4fd added context menu for spell checker actions;
wenzelm
parents: 56575
diff changeset
   431
      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
   432
      range = JEdit_Lib.caret_range(text_area)
66116
dad409cd3423 clarified modules;
wenzelm
parents: 65361
diff changeset
   433
      Text.Info(_, word) <- Spell_Checker.current_word(rendering, range)
56575
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   434
    } {
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   435
      spell_checker.update(word, include, permanent)
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   436
      JEdit_Lib.jedit_views().foreach(_.repaint())
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   437
    }
56574
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   438
  }
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   439
56578
e73723b39c82 proper signature for dynamic BeanShell action;
wenzelm
parents: 56576
diff changeset
   440
  def reset_dictionary()
56575
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   441
  {
65239
509a9b0ad02e avoid global variables with implicit initialization;
wenzelm
parents: 65224
diff changeset
   442
    for (spell_checker <- PIDE.plugin.spell_checker.get)
56575
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   443
    {
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   444
      spell_checker.reset()
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   445
      JEdit_Lib.jedit_views().foreach(_.repaint())
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   446
    }
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   447
  }
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   448
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   449
60878
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   450
  /* debugger */
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   451
60890
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   452
  def toggle_breakpoint(text_area: JEditTextArea): Unit =
65224
wenzelm
parents: 65213
diff changeset
   453
  {
wenzelm
parents: 65213
diff changeset
   454
    GUI_Thread.require {}
wenzelm
parents: 65213
diff changeset
   455
65247
63d91d5de121 tuned signature;
wenzelm
parents: 65240
diff changeset
   456
    if (PIDE.session.debugger.is_active()) {
65224
wenzelm
parents: 65213
diff changeset
   457
      Debugger_Dockable.get_breakpoint(text_area, text_area.getCaretPosition) match {
wenzelm
parents: 65213
diff changeset
   458
        case Some((command, breakpoint)) =>
65247
63d91d5de121 tuned signature;
wenzelm
parents: 65240
diff changeset
   459
          PIDE.session.debugger.toggle_breakpoint(command, breakpoint)
65224
wenzelm
parents: 65213
diff changeset
   460
          jEdit.propertiesChanged()
wenzelm
parents: 65213
diff changeset
   461
        case None =>
wenzelm
parents: 65213
diff changeset
   462
      }
60890
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   463
    }
65224
wenzelm
parents: 65213
diff changeset
   464
  }
60878
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   465
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   466
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   467
  /* plugin options */
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   468
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   469
  def plugin_options(frame: Frame)
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   470
  {
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   471
    GUI_Thread.require {}
61024
7b7f01afab71 avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents: 60890
diff changeset
   472
    jEdit.setProperty("Plugin Options.last", "isabelle-general")
7b7f01afab71 avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents: 60890
diff changeset
   473
    new CombinedOptions(frame, 1)
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   474
  }
65240
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   475
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   476
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   477
  /* popups */
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   478
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   479
  def dismissed_popups(view: View): Boolean =
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   480
  {
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   481
    var dismissed = false
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   482
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   483
    JEdit_Lib.jedit_text_areas(view).foreach(text_area =>
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   484
      if (Completion_Popup.Text_Area.dismissed(text_area)) dismissed = true)
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   485
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   486
    if (Pretty_Tooltip.dismissed_all()) dismissed = true
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   487
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   488
    dismissed
fe5a96240749 clarified modules;
wenzelm
parents: 65239
diff changeset
   489
  }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   490
}