src/Tools/jEdit/src/sledgehammer_dockable.scala
author wenzelm
Wed, 02 Apr 2025 23:18:12 +0200
changeset 82418 6898054035d6
parent 82142 508a673c87ac
permissions -rw-r--r--
support goto_file / hyperlink_file with offset; clarified signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     1
/*  Title:      Tools/jEdit/src/sledgehammer_dockable.scala
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     3
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     4
Dockable window for Sledgehammer.
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     5
*/
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     6
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     7
package isabelle.jedit
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     8
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
     9
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    10
import isabelle._
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    11
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
    12
import scala.swing.{Component, Label}
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    13
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    14
import java.awt.BorderLayout
82142
508a673c87ac removed unused imports;
wenzelm
parents: 81657
diff changeset
    15
import java.awt.event.KeyEvent
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    16
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    17
import org.gjt.sp.jedit.View
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    18
import org.gjt.sp.jedit.gui.HistoryTextField
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    19
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    20
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73987
diff changeset
    21
class Sledgehammer_Dockable(view: View, position: String) extends Dockable(view, position) {
81493
07e79b80e96d clarified signature: avoid implicit functionality;
wenzelm
parents: 81492
diff changeset
    22
  dockable =>
07e79b80e96d clarified signature: avoid implicit functionality;
wenzelm
parents: 81492
diff changeset
    23
61207
wenzelm
parents: 60861
diff changeset
    24
  GUI_Thread.require {}
wenzelm
parents: 60861
diff changeset
    25
wenzelm
parents: 60861
diff changeset
    26
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    27
  /* output text area */
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    28
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    29
  private val output: Output_Area = new Output_Area(view)
61207
wenzelm
parents: 60861
diff changeset
    30
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    31
  override def detach_operation: Option[() => Unit] = output.pretty_text_area.detach_operation
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    32
81493
07e79b80e96d clarified signature: avoid implicit functionality;
wenzelm
parents: 81492
diff changeset
    33
  output.setup(dockable)
07e79b80e96d clarified signature: avoid implicit functionality;
wenzelm
parents: 81492
diff changeset
    34
  set_content(output.text_pane)
56918
a442dc6d244d clarified detach_operation: ignore empty output;
wenzelm
parents: 56715
diff changeset
    35
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    36
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    37
  /* query operation */
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    38
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    39
  private val process_indicator = new Process_Indicator
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    40
78595
b0abf5a9dada clarified signature: prefer enum types;
wenzelm
parents: 76610
diff changeset
    41
  private def consume_status(status: Query_Operation.Status): Unit = {
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    42
    status match {
78595
b0abf5a9dada clarified signature: prefer enum types;
wenzelm
parents: 76610
diff changeset
    43
      case Query_Operation.Status.waiting =>
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    44
        process_indicator.update("Waiting for evaluation of context ...", 5)
78595
b0abf5a9dada clarified signature: prefer enum types;
wenzelm
parents: 76610
diff changeset
    45
      case Query_Operation.Status.running =>
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    46
        process_indicator.update("Sledgehammering ...", 15)
78595
b0abf5a9dada clarified signature: prefer enum types;
wenzelm
parents: 76610
diff changeset
    47
      case Query_Operation.Status.finished =>
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    48
        process_indicator.update(null, 0)
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    49
    }
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    50
  }
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52933
diff changeset
    51
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    52
  private val sledgehammer =
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    53
    new Query_Operation(PIDE.editor, view, "sledgehammer", consume_status,
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
    54
      output.pretty_text_area.update)
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    55
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    56
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    57
  /* controls */
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    58
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
    59
  private def hammer(): Unit = {
60861
fa77faa87d5f maintain history more often;
wenzelm
parents: 60750
diff changeset
    60
    provers.addCurrentToHistory()
56623
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    61
    PIDE.options.string("sledgehammer_provers") = provers.getText
60202
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    62
    sledgehammer.apply_query(
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    63
      List(provers.getText, isar_proofs.selected.toString, try0.selected.toString))
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    64
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    65
52939
3b549ee12623 tuned GUI;
wenzelm
parents: 52935
diff changeset
    66
  private val provers_label = new Label("Provers:") {
54367
e358b79b533a tuned tooltips;
wenzelm
parents: 53872
diff changeset
    67
    tooltip =
56622
891d1b8b64fb clarified tooltip_lines: HTML.encode already takes care of newline (but not space);
wenzelm
parents: 55825
diff changeset
    68
      GUI.tooltip_lines(
60278
2a9bc6447779 clarified tooltip;
wenzelm
parents: 60202
diff changeset
    69
        "Automatic provers as space-separated list, e.g.\n" +
2a9bc6447779 clarified tooltip;
wenzelm
parents: 60202
diff changeset
    70
          PIDE.options.value.check_name("sledgehammer_provers").default_value)
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    71
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    72
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    73
  private val provers = new HistoryTextField("isabelle-sledgehammer-provers") {
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73987
diff changeset
    74
    override def processKeyEvent(evt: KeyEvent): Unit = {
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
    75
      if (evt.getID == KeyEvent.KEY_PRESSED && evt.getKeyCode == KeyEvent.VK_ENTER) hammer()
52933
08bbd321ac4c more active "provers" field, which increases chances that its history is stored;
wenzelm
parents: 52931
diff changeset
    76
      super.processKeyEvent(evt)
08bbd321ac4c more active "provers" field, which increases chances that its history is stored;
wenzelm
parents: 52931
diff changeset
    77
    }
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    78
    setToolTipText(provers_label.tooltip)
53055
0fe8a9972eda some protocol to determine provers according to ML;
wenzelm
parents: 53049
diff changeset
    79
    setColumns(30)
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    80
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    81
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73987
diff changeset
    82
  private def update_provers(): Unit = {
56623
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    83
    val new_provers = PIDE.options.string("sledgehammer_provers")
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    84
    if (new_provers != provers.getText) {
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    85
      provers.setText(new_provers)
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    86
      if (provers.getCaret != null)
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    87
        provers.getCaret.setDot(0)
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    88
    }
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    89
  }
4675df68450e more elementary option sledgehammer_provers, avoiding complications of defaults from ML side (NB: guessing at number of cores does not make sense in PIDE);
wenzelm
parents: 56622
diff changeset
    90
75854
2163772eeaf2 tuned signature;
wenzelm
parents: 75853
diff changeset
    91
  private val isar_proofs = new GUI.Check("Isar proofs") {
60202
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    92
    tooltip = "Specify whether Isar proofs should be output in addition to \"by\" one-liner"
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    93
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
    94
75854
2163772eeaf2 tuned signature;
wenzelm
parents: 75853
diff changeset
    95
  private val try0 = new GUI.Check("Try methods", init = true) {
60202
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    96
    tooltip = "Try standard proof methods like \"auto\" and \"blast\" as alternatives to \"metis\""
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    97
  }
a95023a21725 added checkbox for try0;
wenzelm
parents: 57612
diff changeset
    98
81657
4210fd10e776 clarified signature;
wenzelm
parents: 81493
diff changeset
    99
  private val apply_query = new GUI.Button(GUI.Style_HTML.enclose_bold("Apply")) {
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   100
    tooltip = "Search for first-order proof using automatic theorem provers"
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
   101
    override def clicked(): Unit = hammer()
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   102
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   103
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
   104
  private val cancel_query = new GUI.Button("Cancel") {
52939
3b549ee12623 tuned GUI;
wenzelm
parents: 52935
diff changeset
   105
    tooltip = "Interrupt unfinished sledgehammering"
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
   106
    override def clicked(): Unit = sledgehammer.cancel_query()
52931
ac6648c0c0fb cancel_query via direct access to the exec_id of the running query process;
wenzelm
parents: 52908
diff changeset
   107
  }
ac6648c0c0fb cancel_query via direct access to the exec_id of the running query process;
wenzelm
parents: 52908
diff changeset
   108
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
   109
  private val locate_query = new GUI.Button("Locate") {
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   110
    tooltip = "Locate context of current query within source text"
75853
f981111768ec clarified signature;
wenzelm
parents: 75852
diff changeset
   111
    override def clicked(): Unit = sledgehammer.locate_query()
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   112
  }
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   113
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   114
  private val controls =
66205
e9fa94f43a15 tuned signature;
wenzelm
parents: 66082
diff changeset
   115
    Wrap_Panel(
e9fa94f43a15 tuned signature;
wenzelm
parents: 66082
diff changeset
   116
      List(provers_label, Component.wrap(provers), isar_proofs, try0,
81387
c677755779f5 more uniform pretty_text_area.zoom via its zoom_component;
wenzelm
parents: 78595
diff changeset
   117
        process_indicator.component, apply_query, cancel_query, locate_query,
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
   118
        output.pretty_text_area.zoom_component))
66205
e9fa94f43a15 tuned signature;
wenzelm
parents: 66082
diff changeset
   119
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   120
  add(controls.peer, BorderLayout.NORTH)
53787
e64389fe2d2c focus on default component according to jEdit window management;
wenzelm
parents: 53711
diff changeset
   121
73367
77ef8bef0593 clarified signature --- fewer warnings;
wenzelm
parents: 73340
diff changeset
   122
  override def focusOnDefaultComponent(): Unit = provers.requestFocus()
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   123
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   124
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   125
  /* main */
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   126
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   127
  private val main =
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   128
    Session.Consumer[Session.Global_Options](getClass.getName) {
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
   129
      case _: Session.Global_Options =>
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
   130
        GUI_Thread.later { update_provers(); output.handle_resize() }
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   131
    }
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   132
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73987
diff changeset
   133
  override def init(): Unit = {
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   134
    PIDE.session.global_options += main
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   135
    update_provers()
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
   136
    output.init()
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   137
    sledgehammer.activate()
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   138
  }
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   139
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73987
diff changeset
   140
  override def exit(): Unit = {
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   141
    sledgehammer.deactivate()
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   142
    PIDE.session.global_options -= main
81492
480dffe5741f re-use Output_Area;
wenzelm
parents: 81398
diff changeset
   143
    output.exit()
56624
7eed0fee0241 clarified actor plumbing;
wenzelm
parents: 56623
diff changeset
   144
  }
52908
3461985dcbc3 dockable window for Sledgehammer, based on asynchronous/parallel query operation;
wenzelm
parents:
diff changeset
   145
}