src/Tools/jEdit/src/query_dockable.scala
author wenzelm
Tue, 06 May 2014 16:57:17 +0200
changeset 56879 ee2b61f37ad9
parent 56872 src/Tools/jEdit/src/find_dockable.scala@1435f0c771dc
child 56881 15e18540df10
permissions -rw-r--r--
renamed "Find" to "Query", with more general operations;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
     1
/*  Title:      Tools/jEdit/src/query_dockable.scala
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     3
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
     4
Dockable window for query operations.
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     5
*/
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     6
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     7
package isabelle.jedit
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     8
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
     9
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    10
import isabelle._
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    11
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    12
import java.awt.event.{ComponentEvent, ComponentAdapter, KeyEvent}
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    13
import javax.swing.{JComponent, JTextField}
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    14
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
    15
import scala.swing.{Button, Component, TextField, CheckBox, Label, ListView,
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    16
  ComboBox, TabbedPane, BorderPanel}
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
    17
import scala.swing.event.{SelectionChanged, ButtonClicked, Key, KeyPressed}
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    18
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    19
import org.gjt.sp.jedit.View
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    20
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    21
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
    22
object Query_Dockable
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    23
{
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
    24
  private abstract class Operation(view: View)
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    25
  {
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
    26
    val pretty_text_area = new Pretty_Text_Area(view)
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    27
    def query_operation: Query_Operation[View]
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    28
    def query: JComponent
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
    29
    def select: Unit
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    30
    def page: TabbedPane.Page
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    31
  }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    32
}
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    33
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
    34
class Query_Dockable(view: View, position: String) extends Dockable(view, position)
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    35
{
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    36
  /* common GUI components */
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    37
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    38
  private var zoom_factor = 100
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    39
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    40
  private val zoom =
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    41
    new GUI.Zoom_Box(factor => if (zoom_factor != factor) { zoom_factor = factor; handle_resize() })
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    42
    {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    43
      tooltip = "Zoom factor for output font size"
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    44
    }
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    45
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
    46
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    47
  private def make_query(property: String, tooltip: String, apply_query: () => Unit): JTextField =
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    48
    new Completion_Popup.History_Text_Field(property)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    49
    {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    50
      override def processKeyEvent(evt: KeyEvent)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    51
      {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    52
        if (evt.getID == KeyEvent.KEY_PRESSED && evt.getKeyCode == KeyEvent.VK_ENTER) apply_query()
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    53
        super.processKeyEvent(evt)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    54
      }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    55
      { val max = getPreferredSize; max.width = Integer.MAX_VALUE; setMaximumSize(max) }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    56
      setColumns(40)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    57
      setToolTipText(tooltip)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    58
      setFont(GUI.imitate_font(Font_Info.main_family(), getFont, 1.2))
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    59
    }
52865
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
    60
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    61
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    62
  /* consume status */
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    63
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    64
  def consume_status(process_indicator: Process_Indicator, status: Query_Operation.Status.Value)
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    65
  {
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    66
    status match {
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    67
      case Query_Operation.Status.WAITING =>
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    68
        process_indicator.update("Waiting for evaluation of context ...", 5)
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    69
      case Query_Operation.Status.RUNNING =>
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    70
        process_indicator.update("Running find operation ...", 15)
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: 54368
diff changeset
    71
      case Query_Operation.Status.FINISHED =>
52935
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    72
        process_indicator.update(null, 0)
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    73
    }
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    74
  }
6fc13c31c775 more abstract consume_status operation;
wenzelm
parents: 52886
diff changeset
    75
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    76
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    77
  /* find theorems */
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    78
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
    79
  private val find_theorems = new Query_Dockable.Operation(view)
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    80
  {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    81
    /* query */
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    82
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    83
    private val process_indicator = new Process_Indicator
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    84
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    85
    val query_operation =
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    86
      new Query_Operation(PIDE.editor, view, "find_theorems",
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    87
        consume_status(process_indicator, _),
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    88
        (snapshot, results, body) =>
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    89
          pretty_text_area.update(snapshot, results, Pretty.separate(body)))
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    90
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    91
    private def apply_query()
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    92
    {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    93
      query_operation.apply_query(List(limit.text, allow_dups.selected.toString, query.getText))
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    94
    }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    95
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    96
    private val query_label = new Label("Search criteria:") {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    97
      tooltip =
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    98
        GUI.tooltip_lines(
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
    99
          "Search criteria for find operation, e.g.\n\"_ = _\" \"op +\" name: Group -name: monoid")
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   100
    }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   101
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   102
    val query = make_query("isabelle-find-theorems", query_label.tooltip, apply_query _)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   103
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   104
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   105
    /* GUI page */
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   106
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   107
    private val limit = new TextField(PIDE.options.int("find_theorems_limit").toString, 5) {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   108
      tooltip = "Limit of displayed results"
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   109
      verifier = (s: String) =>
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   110
        s match { case Properties.Value.Int(x) => x >= 0 case _ => false }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   111
      listenTo(keys)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   112
      reactions += { case KeyPressed(_, Key.Enter, 0, _) => apply_query() }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   113
    }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   114
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   115
    private val allow_dups = new CheckBox("Duplicates") {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   116
      tooltip = "Show all versions of matching theorems"
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   117
      selected = false
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   118
    }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   119
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   120
    private val apply_button = new Button("Apply") {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   121
      tooltip = "Find theorems meeting specified criteria"
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   122
      reactions += { case ButtonClicked(_) => apply_query() }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   123
    }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   124
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   125
    private val control_panel =
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   126
      new Wrap_Panel(Wrap_Panel.Alignment.Right)(
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   127
        query_label, Component.wrap(query), limit, allow_dups,
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   128
        process_indicator.component, apply_button)
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   129
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   130
    def select { control_panel.contents += zoom }
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   131
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   132
    val page =
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   133
      new TabbedPane.Page("Find Theorems", new BorderPanel {
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   134
        add(control_panel, BorderPanel.Position.North)
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   135
        add(Component.wrap(pretty_text_area), BorderPanel.Position.Center)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   136
      }, apply_button.tooltip)
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   137
  }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   138
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   139
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   140
  /* find consts */
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   141
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   142
  private val find_consts = new Query_Dockable.Operation(view)
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   143
  {
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   144
    /* query */
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   145
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   146
    private val process_indicator = new Process_Indicator
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   147
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   148
    val query_operation =
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   149
      new Query_Operation(PIDE.editor, view, "find_consts",
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   150
        consume_status(process_indicator, _),
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   151
        (snapshot, results, body) =>
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   152
          pretty_text_area.update(snapshot, results, Pretty.separate(body)))
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   153
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   154
    private def apply_query()
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   155
    {
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   156
      query_operation.apply_query(List(query.getText))
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   157
    }
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   158
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   159
    private val query_label = new Label("Search criteria:") {
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   160
      tooltip = GUI.tooltip_lines("Name / type patterns for constants")
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   161
    }
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   162
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   163
    val query = make_query("isabelle-find-consts", query_label.tooltip, apply_query _)
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   164
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   165
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   166
    /* GUI page */
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   167
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   168
    private val apply_button = new Button("Apply") {
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   169
      tooltip = "Find constants by name / type patterns"
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   170
      reactions += { case ButtonClicked(_) => apply_query() }
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   171
    }
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   172
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   173
    private val control_panel =
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   174
      new Wrap_Panel(Wrap_Panel.Alignment.Right)(
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   175
        query_label, Component.wrap(query), process_indicator.component, apply_button)
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   176
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   177
    def select { control_panel.contents += zoom }
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   178
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   179
    val page =
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   180
      new TabbedPane.Page("Find Constants", new BorderPanel {
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   181
        add(control_panel, BorderPanel.Position.North)
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   182
        add(Component.wrap(pretty_text_area), BorderPanel.Position.Center)
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   183
      }, apply_button.tooltip)
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   184
  }
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   185
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56757
diff changeset
   186
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   187
  /* print operation */
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   188
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   189
  private val print_operation = new Query_Dockable.Operation(view)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   190
  {
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   191
    /* query */
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   192
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   193
    val query_operation =
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   194
      new Query_Operation(PIDE.editor, view, "print_operation", _ => (),
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   195
        (snapshot, results, body) =>
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   196
          pretty_text_area.update(snapshot, results, Pretty.separate(body)))
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   197
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   198
    private def apply_query()
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   199
    {
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   200
      query_operation.apply_query(List(_selector.selection.item))
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   201
    }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   202
56866
c4512e94e15c tuned GUI;
wenzelm
parents: 56865
diff changeset
   203
    private val query_label = new Label("Print:")
c4512e94e15c tuned GUI;
wenzelm
parents: 56865
diff changeset
   204
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   205
    def query: JComponent = _selector.peer.asInstanceOf[JComponent]
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   206
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   207
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   208
    /* items */
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   209
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   210
    case class Item(name: String, description: String)
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   211
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   212
    class Renderer(old_renderer: ListView.Renderer[String], items: List[Item])
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   213
      extends ListView.Renderer[String]
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   214
    {
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   215
      def componentFor(list: ListView[_],
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   216
        selected: Boolean, focused: Boolean, item: String, index: Int) =
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   217
      {
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   218
        val component = old_renderer.componentFor(list, selected, focused, item, index)
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   219
        try { component.tooltip = items(index).description }
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   220
        catch { case _: IndexOutOfBoundsException => }
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   221
        component
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   222
      }
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   223
    }
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   224
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   225
    private var _selector_item: Option[String] = None
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   226
    private var _selector = new ComboBox[String](Nil)
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   227
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   228
    private def set_selector()
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   229
    {
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   230
      val items = Print_Operation.print_operations(PIDE.session).map(p => Item(p._1, p._2))
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   231
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   232
      _selector =
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   233
        new ComboBox(items.map(_.name)) {
56865
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   234
          _selector_item.foreach(item => selection.item = item)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   235
          listenTo(selection)
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   236
          reactions += {
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   237
            case SelectionChanged(_) =>
56865
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   238
              _selector_item = Some(selection.item)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   239
              apply_query()
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   240
          }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   241
        }
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   242
      _selector.renderer = new Renderer(_selector.renderer, items)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   243
    }
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   244
    set_selector()
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   245
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   246
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   247
    /* GUI page */
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   248
56865
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   249
    private val apply_button = new Button("Apply") {
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   250
      tooltip = "Apply to current context"
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   251
      reactions += { case ButtonClicked(_) => apply_query() }
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   252
    }
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   253
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   254
    private val control_panel = new Wrap_Panel(Wrap_Panel.Alignment.Right)()
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   255
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   256
    def select
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   257
    {
56872
1435f0c771dc some complication with ListView.Renderer to get tooltips;
wenzelm
parents: 56866
diff changeset
   258
      set_selector()
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   259
      control_panel.contents.clear
56866
c4512e94e15c tuned GUI;
wenzelm
parents: 56865
diff changeset
   260
      control_panel.contents ++= List(query_label, _selector, apply_button, zoom)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   261
    }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   262
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   263
    val page =
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   264
      new TabbedPane.Page("Print Context", new BorderPanel {
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   265
        add(control_panel, BorderPanel.Position.North)
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   266
        add(Component.wrap(pretty_text_area), BorderPanel.Position.Center)
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   267
      }, "Print information from context")
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   268
  }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   269
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   270
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   271
  /* operations */
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   272
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents: 56759
diff changeset
   273
  private val operations = List(find_theorems, find_consts, print_operation)
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   274
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   275
  private val operations_pane = new TabbedPane
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   276
  {
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   277
    pages ++= operations.map(_.page)
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   278
    listenTo(selection)
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   279
    reactions += { case SelectionChanged(_) => select_operation() }
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   280
  }
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   281
56879
ee2b61f37ad9 renamed "Find" to "Query", with more general operations;
wenzelm
parents: 56872
diff changeset
   282
  private def get_operation(): Option[Query_Dockable.Operation] =
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   283
    try { Some(operations(operations_pane.selection.index)) }
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   284
    catch { case _: IndexOutOfBoundsException => None }
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   285
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   286
  private def select_operation() {
56865
168766e28f5e more decisive change of focus;
wenzelm
parents: 56864
diff changeset
   287
    for (op <- get_operation()) { op.select; op.query.requestFocus }
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   288
    operations_pane.revalidate
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   289
  }
52865
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   290
56759
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   291
  override def focusOnDefaultComponent { for (op <- get_operation()) op.query.requestFocus }
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   292
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   293
  select_operation()
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   294
  set_content(operations_pane)
790f7562cd0e proper handling of shared zoom component: update layout dynamically;
wenzelm
parents: 56758
diff changeset
   295
52865
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   296
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   297
  /* resize */
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   298
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   299
  private def handle_resize(): Unit =
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   300
    Swing_Thread.require {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   301
      for (op <- operations) {
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   302
        op.pretty_text_area.resize(
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   303
          Font_Info.main(PIDE.options.real("jedit_font_scale") * zoom_factor / 100))
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   304
      }
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   305
    }
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   306
52865
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   307
  private val delay_resize =
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   308
    Swing_Thread.delay_first(PIDE.options.seconds("editor_update_delay")) { handle_resize() }
52854
92932931bd82 more general Output.result: allow to update arbitrary properties;
wenzelm
parents: 52851
diff changeset
   309
52865
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   310
  addComponentListener(new ComponentAdapter {
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   311
    override def componentResized(e: ComponentEvent) { delay_resize.invoke() }
02a7e7180ee5 slightly more general support for one-shot query operations via asynchronous print functions and temporary document overlay;
wenzelm
parents: 52864
diff changeset
   312
  })
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   313
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   314
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   315
  /* main */
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   316
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   317
  private val main =
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   318
    Session.Consumer[Session.Global_Options](getClass.getName) {
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   319
      case _: Session.Global_Options => Swing_Thread.later { handle_resize() }
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   320
    }
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   321
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   322
  override def init()
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   323
  {
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   324
    PIDE.session.global_options += main
52848
9489ca1d55dd some tracking of command location;
wenzelm
parents: 52846
diff changeset
   325
    handle_resize()
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   326
    operations.foreach(op => op.query_operation.activate())
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   327
  }
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   328
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   329
  override def exit()
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   330
  {
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   331
    operations.foreach(op => op.query_operation.deactivate())
56715
52125652e82a clarified Session.Consumer, with Session.Outlet managed by dispatcher thread;
wenzelm
parents: 56662
diff changeset
   332
    PIDE.session.global_options -= main
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   333
    delay_resize.revoke()
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   334
  }
56757
d6fdf08282f3 some rearrangements to support multiple find operations;
wenzelm
parents: 56751
diff changeset
   335
}
52846
82ac963c68cb dockable window for "find" dialog (GUI only);
wenzelm
parents:
diff changeset
   336