src/Tools/jEdit/src/isabelle.scala
author wenzelm
Wed, 14 Sep 2016 14:07:09 +0200
changeset 63868 22037a819276
parent 63865 ccac33e291b1
child 64456 f630e9385d7e
permissions -rw-r--r--
more robust;
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 {
63865
wenzelm
parents: 63809
diff changeset
    53
      case "isabelle" => Some(PIDE.resources.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
22037a819276 more robust;
wenzelm
parents: 63865
diff changeset
    66
      (JEdit_Lib.buffer_mode(buffer), PIDE.document_model(buffer)) match {
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))): _*) +
58546
72e2b2a609c4 clarified modules;
wenzelm
parents: 58543
diff changeset
    77
      ("bibtex" -> new Bibtex_JEdit.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
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   231
  private def node_required_update(view: View, toggle: Boolean = false, set: Boolean = false)
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   232
  {
57612
990ffb84489b clarified module name: facilitate alternative GUI frameworks;
wenzelm
parents: 57424
diff changeset
   233
    GUI_Thread.require {}
52815
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   234
    PIDE.document_model(view.getBuffer) match {
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   235
      case Some(model) =>
52816
c608e0ade554 home-grown mouse handling to pretend that the painted checkbox is actually a Swing component;
wenzelm
parents: 52815
diff changeset
   236
        model.node_required = (if (toggle) !model.node_required else set)
52815
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   237
      case None =>
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   238
    }
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   239
  }
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   240
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   241
  def set_node_required(view: View) { node_required_update(view, set = true) }
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   242
  def reset_node_required(view: View) { node_required_update(view, set = false) }
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   243
  def toggle_node_required(view: View) { node_required_update(view, toggle = true) }
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   244
eaad5fe7bb1b actions and shortcuts to change node_required status, with painter that looks like CheckBox (non-clickable);
wenzelm
parents: 51533
diff changeset
   245
50198
0c7b351a6871 added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents: 50187
diff changeset
   246
  /* font size */
0c7b351a6871 added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents: 50187
diff changeset
   247
55827
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   248
  def reset_font_size() {
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   249
    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
   250
  }
55827
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   251
  def increase_font_size() { Font_Info.main_change.step(1) }
8a881f83e206 clarified module structure;
wenzelm
parents: 55825
diff changeset
   252
  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
   253
0c7b351a6871 added convenience actions isabelle.increase-font-size and isabelle.decrease-font-size;
wenzelm
parents: 50187
diff changeset
   254
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   255
  /* structured edits */
50341
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   256
63455
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   257
  def newline(text_area: TextArea)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   258
  {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   259
    if (!text_area.isEditable()) text_area.getToolkit().beep()
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   260
    else {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   261
      val buffer = text_area.getBuffer
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   262
      def nl { text_area.userInput('\n') }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   263
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   264
      if (indent_rule(JEdit_Lib.buffer_mode(buffer)).isDefined &&
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   265
          buffer.getStringProperty("autoIndent") == "full" &&
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   266
          PIDE.options.bool("jedit_indent_newline"))
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   267
      {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   268
        Isabelle.buffer_syntax(buffer) match {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   269
          case Some(syntax) if buffer.isInstanceOf[Buffer] =>
63484
2033a3960c36 auto indentation of quasi commands;
wenzelm
parents: 63477
diff changeset
   270
            val keywords = syntax.keywords
2033a3960c36 auto indentation of quasi commands;
wenzelm
parents: 63477
diff changeset
   271
63455
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   272
            val caret = text_area.getCaretPosition
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   273
            val line = text_area.getCaretLine
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   274
            val line_range = JEdit_Lib.line_range(buffer, line)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   275
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   276
            def line_content(start: Text.Offset, stop: Text.Offset, context: Scan.Line_Context)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   277
              : (List[Token], Scan.Line_Context) =
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   278
            {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   279
              val text = JEdit_Lib.try_get_text(buffer, Text.Range(start, stop)).getOrElse("")
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   280
              val (toks, context1) = Token.explode_line(syntax.keywords, text, context)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   281
              val toks1 = toks.filterNot(_.is_space)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   282
              (toks1, context1)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   283
            }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   284
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   285
            val context0 = Token_Markup.Line_Context.prev(buffer, line).get_context
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   286
            val (tokens1, context1) = line_content(line_range.start, caret, context0)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   287
            val (tokens2, _) = line_content(caret, line_range.stop, context1)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   288
63809
wenzelm
parents: 63508
diff changeset
   289
            if (tokens1.nonEmpty && keywords.is_indent_command(tokens1.head))
63477
f5c81436b930 clarified indentation: 'begin' is treated like a separate command without indent;
wenzelm
parents: 63455
diff changeset
   290
              buffer.indentLine(line, true)
63455
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   291
63809
wenzelm
parents: 63508
diff changeset
   292
            if (tokens2.isEmpty || keywords.is_indent_command(tokens2.head))
63455
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   293
              JEdit_Lib.buffer_edit(buffer) {
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   294
                text_area.setSelectedText("\n")
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   295
                if (!buffer.indentLine(line + 1, true)) text_area.goToStartOfWhiteSpace(false)
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   296
              }
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   297
            else nl
019856db2bb6 added action "isabelle.newline" (shortcut ENTER);
wenzelm
parents: 63444
diff changeset
   298
          case _ => nl
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 =
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   312
            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
   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
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   323
  def edit_command(
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   324
    snapshot: Document.Snapshot,
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   325
    text_area: TextArea,
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   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
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   328
    text: String)
53497
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   329
  {
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   330
    val buffer = text_area.getBuffer
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   331
    if (!snapshot.is_outdated && text != "") {
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
   332
      (snapshot.state.find_command(snapshot.version, id), PIDE.document_model(buffer)) match {
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) {
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
                val range = command.proper_range + start
63508
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   338
                JEdit_Lib.buffer_edit(buffer) {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   339
                  if (padding) {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   340
                    text_area.moveCaretPosition(start + range.length)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   341
                    text_area.setSelectedText("\n" + text)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   342
                    val end_line = text_area.getCaretLine
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   343
                    val start_line = end_line - split_lines(text).length
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   344
                    buffer.indentLines(start_line, end_line)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   345
                  }
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   346
                  else {
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   347
                    buffer.remove(start, range.length)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   348
                    text_area.moveCaretPosition(start)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   349
                    text_area.setSelectedText(text)
348599644887 more structured edit, including indentation;
wenzelm
parents: 63484
diff changeset
   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
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   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
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   357
    }
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   358
  }
07bb77881b8d tuned signature;
wenzelm
parents: 53322
diff changeset
   359
50341
0c65a7cfc0f3 provide general insert_line_padding as convenience operation, e.g. for BeanShell macros;
wenzelm
parents: 50299
diff changeset
   360
63236
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   361
  /* selection */
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   362
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   363
  def select_entity(text_area: JEditTextArea)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   364
  {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   365
    for {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   366
      doc_view <- PIDE.document_view(text_area)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   367
      rendering = doc_view.get_rendering()
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   368
    } {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   369
      val caret_range = JEdit_Lib.caret_range(text_area)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   370
      val buffer_range = JEdit_Lib.buffer_range(text_area.getBuffer)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   371
      val active_focus = rendering.caret_focus_ranges(caret_range, buffer_range)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   372
      if (active_focus.nonEmpty) {
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   373
        text_area.selectNone()
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   374
        for (r <- active_focus)
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   375
          text_area.addToSelection(new Selection.Range(r.start, r.stop))
48bc9045866e added action "isabelle.select-entity";
wenzelm
parents: 62631
diff changeset
   376
      }
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
53293
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   381
  /* completion */
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   382
56586
5ef60881681d explicit menu action to complete word;
wenzelm
parents: 56578
diff changeset
   383
  def complete(view: View, word_only: Boolean)
53293
fd27b8f5a479 added action isabelle.complete, using standard jEdit keyboard shortcut;
wenzelm
parents: 53281
diff changeset
   384
  {
57424
966b12f636b9 removed slightly odd fall-back on complete-word (NB: connection to default menu action is unclear);
wenzelm
parents: 56879
diff changeset
   385
    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
   386
  }
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
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   389
  /* control styles */
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   390
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   391
  def control_sub(text_area: JEditTextArea)
62104
fb73c0d7bb37 clarified symbol insertion, depending on buffer encoding;
wenzelm
parents: 61802
diff changeset
   392
  { Token_Markup.edit_control_style(text_area, Symbol.sub) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   393
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   394
  def control_sup(text_area: JEditTextArea)
62104
fb73c0d7bb37 clarified symbol insertion, depending on buffer encoding;
wenzelm
parents: 61802
diff changeset
   395
  { Token_Markup.edit_control_style(text_area, Symbol.sup) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   396
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   397
  def control_bold(text_area: JEditTextArea)
62104
fb73c0d7bb37 clarified symbol insertion, depending on buffer encoding;
wenzelm
parents: 61802
diff changeset
   398
  { Token_Markup.edit_control_style(text_area, Symbol.bold) }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   399
61483
07c8d5d8acab added action "isabelle-emph";
wenzelm
parents: 61211
diff changeset
   400
  def control_emph(text_area: JEditTextArea)
62104
fb73c0d7bb37 clarified symbol insertion, depending on buffer encoding;
wenzelm
parents: 61802
diff changeset
   401
  { Token_Markup.edit_control_style(text_area, Symbol.emph) }
61483
07c8d5d8acab added action "isabelle-emph";
wenzelm
parents: 61211
diff changeset
   402
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   403
  def control_reset(text_area: JEditTextArea)
50187
b5a09812abc4 special handling of control symbols in Symbols dockable;
wenzelm
parents: 50183
diff changeset
   404
  { Token_Markup.edit_control_style(text_area, "") }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   405
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   406
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   407
  /* block styles */
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   408
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   409
  private def enclose_input(text_area: JEditTextArea, s1: String, s2: String)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   410
  {
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   411
    s1.foreach(text_area.userInput(_))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   412
    s2.foreach(text_area.userInput(_))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   413
    s2.foreach(_ => text_area.goToPrevCharacter(false))
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   414
  }
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   415
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   416
  def input_bsub(text_area: JEditTextArea)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   417
  { enclose_input(text_area, Symbol.bsub_decoded, Symbol.esub_decoded) }
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   418
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   419
  def input_bsup(text_area: JEditTextArea)
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   420
  { enclose_input(text_area, Symbol.bsup_decoded, Symbol.esup_decoded) }
56574
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   421
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
  /* spell-checker dictionary */
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   424
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   425
  def update_dictionary(text_area: JEditTextArea, include: Boolean, permanent: Boolean)
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   426
  {
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   427
    for {
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   428
      spell_checker <- PIDE.spell_checker.get
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   429
      doc_view <- PIDE.document_view(text_area)
56576
86148ca3c4fd added context menu for spell checker actions;
wenzelm
parents: 56575
diff changeset
   430
      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
   431
      range = JEdit_Lib.caret_range(text_area)
56576
86148ca3c4fd added context menu for spell checker actions;
wenzelm
parents: 56575
diff changeset
   432
      Text.Info(_, word) <- Spell_Checker.current_word(text_area, rendering, range)
56575
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   433
    } {
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   434
      spell_checker.update(word, include, permanent)
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   435
      JEdit_Lib.jedit_views().foreach(_.repaint())
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   436
    }
56574
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   437
  }
2b38472a4695 some actions to maintain spell-checker dictionary;
wenzelm
parents: 56394
diff changeset
   438
56578
e73723b39c82 proper signature for dynamic BeanShell action;
wenzelm
parents: 56576
diff changeset
   439
  def reset_dictionary()
56575
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   440
  {
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   441
    for (spell_checker <- PIDE.spell_checker.get)
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   442
    {
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   443
      spell_checker.reset()
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   444
      JEdit_Lib.jedit_views().foreach(_.repaint())
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   445
    }
cdd609ea595d full repaint after dictionary update;
wenzelm
parents: 56574
diff changeset
   446
  }
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   447
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   448
60878
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   449
  /* debugger */
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   450
60890
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   451
  def toggle_breakpoint(text_area: JEditTextArea): Unit =
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   452
    if (Debugger.is_active()) {
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   453
      for {
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   454
        (command, serial) <- Debugger_Dockable.get_breakpoint(text_area, text_area.getCaretPosition)
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   455
      } Debugger_Dockable.toggle_breakpoint(command, serial)
e2aeaa397e93 GUI actions depend on active debugger;
wenzelm
parents: 60880
diff changeset
   456
    }
60878
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   457
1f0d2bbcf38b added action to toggle breakpoints (on editor side);
wenzelm
parents: 60843
diff changeset
   458
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   459
  /* plugin options */
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   460
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   461
  def plugin_options(frame: Frame)
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   462
  {
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   463
    GUI_Thread.require {}
61024
7b7f01afab71 avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents: 60890
diff changeset
   464
    jEdit.setProperty("Plugin Options.last", "isabelle-general")
7b7f01afab71 avoid deprecated PluginOptions with its unbounded window size;
wenzelm
parents: 60890
diff changeset
   465
    new CombinedOptions(frame, 1)
57627
65fc7ae1bf66 added action "isabelle.options" (despite problems with initial window size);
wenzelm
parents: 57612
diff changeset
   466
  }
50183
2b3e24e1c9e7 improved editing support for control styles;
wenzelm
parents:
diff changeset
   467
}