lib/jedit/plugin/isabelle_dock.scala
author wenzelm
Wed, 15 Apr 2009 11:14:48 +0200
changeset 30895 bad26d8f0adf
parent 28006 116b9c1d402f
permissions -rw-r--r--
updated for Isabelle2009;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     1
/*  Title:      lib/jedit/plugin/isabelle_dock.scala
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     3
    Author:     Makarius
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     4
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     5
Dockable window for Isabelle process control.
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     6
*/
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     7
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     8
package isabelle.jedit
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
     9
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    10
import org.gjt.sp.jedit.View
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    11
import org.gjt.sp.jedit.gui.DefaultFocusComponent
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    12
import org.gjt.sp.jedit.gui.DockableWindowManager
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    13
import org.gjt.sp.jedit.gui.RolloverButton
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    14
import org.gjt.sp.jedit.gui.HistoryTextField
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    15
import org.gjt.sp.jedit.GUIUtilities
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    16
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    17
import java.awt.Color
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    18
import java.awt.Insets
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    19
import java.awt.BorderLayout
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    20
import java.awt.Dimension
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    21
import java.awt.event.ActionListener
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    22
import java.awt.event.ActionEvent
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    23
import javax.swing.BoxLayout
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    24
import javax.swing.JPanel
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    25
import javax.swing.JScrollPane
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    26
import javax.swing.JTextPane
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    27
import javax.swing.text.{StyledDocument, StyleConstants}
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    28
import javax.swing.SwingUtilities
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    29
import javax.swing.Icon
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    30
import javax.swing.Box
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    31
import javax.swing.JTextField
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    32
import javax.swing.JComboBox
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    33
import javax.swing.DefaultComboBoxModel
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    34
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    35
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    36
class IsabelleDock(view: View, position: String)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    37
    extends JPanel(new BorderLayout) with DefaultFocusComponent
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    38
{
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    39
  private val text = new HistoryTextField("isabelle", false, true)
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    40
  private val logic_combo = new JComboBox
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    41
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    42
  {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    43
    // output pane
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    44
    val pane = new JTextPane
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    45
    pane.setEditable(false)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    46
    add(BorderLayout.CENTER, new JScrollPane(pane))
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    47
    if (position == DockableWindowManager.FLOATING)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    48
      setPreferredSize(new Dimension(1000, 500))
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    49
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    50
    val doc = pane.getDocument.asInstanceOf[StyledDocument]
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    51
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    52
    def make_style(name: String, bg: Boolean, color: Color) = {
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    53
      val style = doc.addStyle(name, null)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    54
      if (bg) StyleConstants.setBackground(style, color)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    55
      else StyleConstants.setForeground(style, color)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    56
      style
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    57
    }
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    58
    val raw_style = make_style("raw", false, Color.GRAY)
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    59
    val info_style = make_style("info", true, new Color(160, 255, 160))
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    60
    val warning_style = make_style("warning", true, new Color(255, 255, 160))
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    61
    val error_style = make_style("error", true, new Color(255, 160, 160))
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    62
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    63
    IsabellePlugin.add_permanent_consumer (result =>
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    64
      if (result != null && !result.is_system) {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    65
        SwingUtilities.invokeLater(new Runnable {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    66
          def run = {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    67
            val logic = IsabellePlugin.isabelle.session
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    68
            logic_combo.setModel(new DefaultComboBoxModel(Array(logic).asInstanceOf[Array[AnyRef]]))
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    69
            logic_combo.setPrototypeDisplayValue("AAAA")  // FIXME ??
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    70
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    71
            val doc = pane.getDocument.asInstanceOf[StyledDocument]
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    72
            val style = result.kind match {
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    73
              case IsabelleProcess.Kind.WARNING => warning_style
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    74
              case IsabelleProcess.Kind.ERROR => error_style
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    75
              case IsabelleProcess.Kind.TRACING => info_style
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    76
              case _ => if (result.is_raw) raw_style else null
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    77
            }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    78
            doc.insertString(doc.getLength, IsabellePlugin.result_content(result), style)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    79
            if (!result.is_raw) doc.insertString(doc.getLength, "\n", style)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    80
            pane.setCaretPosition(doc.getLength)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    81
          }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    82
        })
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    83
      })
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    84
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    85
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    86
    // control box
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    87
    val box = new Box(BoxLayout.X_AXIS)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    88
    add(BorderLayout.SOUTH, box)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    89
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    90
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    91
    // logic combo
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    92
    logic_combo.setToolTipText("Isabelle logics")
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    93
    logic_combo.setRequestFocusEnabled(false)
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    94
    logic_combo.setModel(new DefaultComboBoxModel(Array("default").asInstanceOf[Array[AnyRef]]))
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    95
    box.add(logic_combo)
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    96
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    97
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
    98
    // mode combo
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
    99
    val mode_Isar = "Isar"
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   100
    val mode_ML = "ML"
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   101
    val modes = Array(mode_Isar, mode_ML)
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   102
    var mode = mode_Isar
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   103
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   104
    val mode_combo = new JComboBox
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   105
    mode_combo.setToolTipText("Toplevel mode")
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   106
    mode_combo.setRequestFocusEnabled(false)
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   107
    mode_combo.setModel(new DefaultComboBoxModel(modes.asInstanceOf[Array[AnyRef]]))
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   108
    mode_combo.setPrototypeDisplayValue("AAAA")
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   109
    mode_combo.addActionListener(new ActionListener {
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   110
      def actionPerformed(evt: ActionEvent): Unit = {
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   111
        mode = mode_combo.getSelectedItem.asInstanceOf[String]
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   112
      }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   113
    })
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   114
    box.add(mode_combo)
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   115
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   116
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   117
    // input field
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   118
    text.setToolTipText("Command line")
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   119
    text.addActionListener(new ActionListener {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   120
      def actionPerformed(evt: ActionEvent): Unit = {
28006
116b9c1d402f command: symbols.encode;
wenzelm
parents: 27996
diff changeset
   121
        val command = IsabellePlugin.symbols.encode(text.getText)
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   122
        if (command.length > 0) {
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   123
          if (mode == mode_Isar)
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   124
            IsabellePlugin.isabelle.command(command)
27988
efc6d38d16d2 misc tuning of names;
wenzelm
parents: 27987
diff changeset
   125
          else if (mode == mode_ML)
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   126
            IsabellePlugin.isabelle.ML(command)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   127
          text.setText("")
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   128
        }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   129
      }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   130
    })
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   131
    box.add(text)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   132
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   133
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   134
    // buttons
27996
wenzelm
parents: 27988
diff changeset
   135
    def icon_button(icon: String, tip: String, action: => Unit) = {
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   136
      val button = new RolloverButton(GUIUtilities.loadIcon(icon))
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   137
      button.setToolTipText(tip)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   138
      button.setMargin(new Insets(0,0,0,0))
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   139
      button.setRequestFocusEnabled(false)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   140
      button.addActionListener(new ActionListener {
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   141
        def actionPerformed(evt: ActionEvent): Unit = action
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   142
      })
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   143
      box.add(button)
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   144
    }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   145
27996
wenzelm
parents: 27988
diff changeset
   146
    icon_button("Cancel.png", "Stop", IsabellePlugin.isabelle.interrupt)
wenzelm
parents: 27988
diff changeset
   147
    icon_button("Clear.png", "Clear", pane.setText(""))
27987
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   148
  }
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   149
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   150
  def focusOnDefaultComponent: Unit = text.requestFocus
c3f7fa72af2a rearranged source files;
wenzelm
parents:
diff changeset
   151
}